首頁 資料庫 mysql教程 SQL Server中,实现二进制与字符类型之间的数据转换

SQL Server中,实现二进制与字符类型之间的数据转换

Jun 07, 2016 pm 05:40 PM
sql sql server 函數

在工控应用上,返回的数据经常会以二进制的形成存储,而这些二进制数据又是以每4个bit表示一个十六进制的数据内容。解析的时候,往往是一个字节(Byte)占用8个

 

在工控应用上,香港虚拟主机,返回的数据经常会以二进制的形成存储,而这些二进制数据又是以每4个bit表示一个十六进制的数据内容。解析的时候,香港服务器租用,往往是一个字节(Byte)占用8个位(bit),高位4bit 表示一个十六进制数据,低位4bit 表示一个十六进制数据。

 

问题描述:在SQL Server 数据库中,如何实现二进制数据与字符串数据之间的直接转换?

一定会有人立马反问我:为什么不在程序中使用 C# 或者 JAVA 或者 C++ 来处理这个业务呢?我的回答是:这个我知道,也已经实现了。但在一些特殊的应用环境和业务需求面前(如:对数据的统计、对数据的分析),我必须这么做!

 

SQL Server 数据库中,实现 varbinary 类型转换成 varchar 类型

实现的思路是:

每次取得 varbinary 中一个字节的数据,然后除以16 获得高位的4bit数据,再模16获得低位的4bit数据;分别从固定字符串中以下标的形式匹配对应的字符,最后累加起来即可。

代码如下:

测试示例:

select dbo.varbin2hexstr(0x1432fabcdef1234567890)

 

SQL Server 数据库中,实现 varchar 类型转换成 varbinary 类型

一定会有人立马想到:既然已经实现了varbinary 类型转换成 varchar 类型,接下来需要做的,只是将函数逆向反转实现便可。但实现也并非如此!实现的思路是:

先将整个字符串按照每两位分组;

     为什么不按照每8位或每4位进行分组?是为了考虑到函数的通用性。

     如果按照每 8位 或者 每4位 分组,则整个字符串必须是8或者4的倍数,否则将出现字符不足,前面补 0的情况。

然后对每个字符进行处理,如:字符“A B C D E F” 对应转换为“10 11 12 13 14 15”;

接着对每2个字符进行 16 的幂运算,并求和。如: AB = 10 * 16的一次方 + 11 * 16的零次方;

再将这个2个字符的整数和,转换为一个字节(Byte)长度的 varbinary 数据;

最后将所有的 varbinary 数据直接相加即可。

代码如下:

测试示例:

)

(完)

【2012年度IT博客大赛】我的参赛主页

记得帮我投票哦 ~ 谢谢!

本文出自 “xugang” 博客,请务必保留此出处

,美国服务器
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

golang函數動態建立新函數的技巧 golang函數動態建立新函數的技巧 Apr 25, 2024 pm 02:39 PM

Go語言提供了兩種動態函數創建技術:closures和反射。 closures允許存取閉包作用域內的變量,而反射可使用FuncOf函數建立新函數。這些技術在自訂HTTP路由器、實現高度可自訂的系統和建置可插拔的元件方面非常有用。

C++ 函數命名中參數順序的考慮 C++ 函數命名中參數順序的考慮 Apr 24, 2024 pm 04:21 PM

在C++函數命名中,考慮參數順序至關重要,可提高可讀性、減少錯誤並促進重構。常見的參數順序約定包括:動作-物件、物件-動作、語意意義和遵循標準函式庫。最佳順序取決於函數目的、參數類型、潛在混淆和語言慣例。

excel函數公式大全 excel函數公式大全 May 07, 2024 pm 12:04 PM

1. SUM函數,用於對一列或一組單元格中的數字進行求和,例如:=SUM(A1:J10)。 2、AVERAGE函數,用於計算一列或一組儲存格中的數字的平均值,例如:=AVERAGE(A1:A10)。 3.COUNT函數,用於計算一列或一組單元格中的數字或文字的數量,例如:=COUNT(A1:A10)4、IF函數,用於根據指定的條件進行邏輯判斷,並返回相應的結果。

如何在Java中寫出高效和可維護的函數? 如何在Java中寫出高效和可維護的函數? Apr 24, 2024 am 11:33 AM

編寫高效且可維護的Java函數的關鍵在於:保持簡潔。使用有意義的命名。處理特殊情況。使用適當的可見性。

C++ 函式異常進階:客製化錯誤處理 C++ 函式異常進階:客製化錯誤處理 May 01, 2024 pm 06:39 PM

C++中的異常處理可透過自訂異常類別增強,提供特定錯誤訊息、上下文資訊以及根據錯誤類型執行自訂操作。定義繼承自std::exception的異常類,提供特定的錯誤訊息。使用throw關鍵字拋出自訂異常。在try-catch區塊中使用dynamic_cast將捕獲到的異常轉換為自訂異常類型。在實戰案例中,open_file函數會拋出FileNotFoundException異常,捕捉並處理該異常可提供更具體的錯誤訊息。

Golang 函數接收 map 參數時的注意事項 Golang 函數接收 map 參數時的注意事項 Jun 04, 2024 am 10:31 AM

在Go中傳遞map給函數時,預設會建立副本,對副本的修改不影響原map。如果需要修改原始map,可透過指標傳遞。空map需小心處理,因為技術上是nil指針,傳遞空map給期望非空map的函數會發生錯誤。

在 C++ 中使用函數傳回值:詳解類型和意義 在 C++ 中使用函數傳回值:詳解類型和意義 May 01, 2024 am 08:27 AM

函數傳回值在C++中至關重要,它允許函數傳回指定類型的資料:傳回值型別定義函數傳回資料的類型,包括基本型別(如int、float)和自訂型別(如指標、參考)。傳回值意義根據函數意圖而異,例如傳回結果、指示狀態、提供引用或建立新物件。

如何在 Golang 中使用 SQL 與 JSON 資料互動? 如何在 Golang 中使用 SQL 與 JSON 資料互動? Jun 03, 2024 am 11:47 AM

在Golang中透過SQL與JSON資料互動共有以下步驟:使用json.Unmarshal函數將JSON資料解析為Go結構體,實作JSON到結構體的轉換。使用database/sql套件存取和操作SQL資料庫,執行諸如插入、查詢等操作。結合上述步驟,可以在Go中建立基於SQL和JSON的應用,實現用戶註冊和登入等功能。

See all articles