- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章SQL Server中实现二进制与字符类型之间的数据转换由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在工控应用上,返回的数据经常会以二进制的形成存储,而这些二进制数据又是以每4个bit表示一个十六进制的数据内容。解析的时候,往往是一个字节(Byte)占用8个位(bit),高位4bit 表示一个十六进制数据,低位4bit 表示一个十六进制数据。 问题描述:在SQL Server 数据库中,如何实现二进制数据与字符串数据之间的直接转换? 一定会有人立马反问我:为什么不在程序中使用 C# 或者 JAVA 或者 C++ 来处理这个业务呢?我的回答是:这个我知道,也已经实现了。但在一些特殊的应用环境和业务需求面前(如:对数据的统计、对数据的分析),我必须这么做! SQL Server 数据库中,实现 varbinary 类型转换成 varchar 类型 实现的思路是: 每次取得 varbinary 中一个字节的数据,然后除以16 获得高位的4bit数据,再模16获得低位的4bit数据;分别从固定字符串中以下标的形式匹配对应的字符,最后累加起来即可。 代码如下: 。
复制代码代码如下
--============================================== -- FUNCTION varbin2hexstr -- 将 varbinary 类型的数据转换为 varchar 类型 --============================================== IF OBJECT_ID ('dbo.varbin2hexstr') IS NOT NULL DROP FUNCTION dbo.varbin2hexstr GO CREATE function varbin2hexstr( @bin varbinary(8000) )returns varchar(8000) as begin declare @re varchar(8000),@i int select @re='',@i=datalength(@bin) while @i>0 select @re=substring('0123456789ABCDEF',substring(@bin,@i,1)/16+1,1) +substring('0123456789ABCDEF',substring(@bin,@i,1)%16+1,1) +@re ,@i=@i-1 -- return('0x'+@re) return @re end GO 。
测试示例: 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 数据直接相加即可。 代码如下: 。
复制代码代码如下
--============================================== -- FUNCTION hexstr2varbin -- 将 varchar 类型的数据转换为 varbinary 类型 --============================================== IF OBJECT_ID ('dbo.hexstr2varbin') IS NOT NULL DROP FUNCTION dbo.hexstr2varbin GO CREATE function [dbo].[hexstr2varbin]( @char varchar(8000) )returns varbinary(8000) as begin declare @re varbinary(8000), @tempchar varchar(2), @getchar varchar(1), @getint int, @n int, @totalint int, @i int, @tempint int, @runNum int -- 字符串截取段数 select @tempchar='',@i=datalength(@char), @re=0x; if( @i>0) begin if ( @i%2 = 0) set @runNum= @i/2 else set @runNum= @i/2 + 1 while (@runNum > 0) begin if(@runNum = 1) set @tempchar = @char else set @tempchar = substring(@char, (@runNum-1)*2,2) select @n=1,@totalint=0; -- 循环处理截取的每个字符串 (这里的字符串长度为2) while @n < ( datalength(@tempchar) + 1 ) begin set @getchar=substring(@tempchar,@n,1); -- 将字符转换为十六进制对应的数字 select @getint=case when @getchar='a' then 10 when @getchar='b' then 11 when @getchar='c' then 12 when @getchar='d' then 13 when @getchar='e' then 14 when @getchar='f' then 15 else convert(int,@getchar) end; set @tempint=@getint*power(16,datalength(@tempchar)-@n) set @totalint = @totalint + @tempint set @n=@n+1 end set @re=convert(varbinary(1),@totalint) + @re; set @runNum=@runNum-1; end end return @re end GO 。
测试示例: 。
复制代码代码如下
select dbo.hexstr2varbin('ffffff2353f5feefaffae1fff1ffbaf1faffa33333333ff3aaafffffffaaff') 。
(完) 本文出自 “xugang” 博客,请务必保留此出处http://guangrou.blog.51cto.com/404164/1040606 。
最后此篇关于SQL Server中实现二进制与字符类型之间的数据转换的文章就讲到这里了,如果你想了解更多关于SQL Server中实现二进制与字符类型之间的数据转换的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在尝试将谷歌地图集成到 Xamarin Android。但是,如标题中所写,收到错误。此错误出现在我的 SetContentView (Resource.Layout.Main); 上,如下所示:
在 Delphi 中如何以非文本模式打开二进制文件?类似于 C 函数 fopen(filename,"rb") 最佳答案 有几个选项。 1。使用文件流 var Stream: TFileStrea
我现在正在处理一个问题,如下所示: 有两个数字 x1 和 x2 并且 x2 > x1。 例如 x1 = 5; x2 = 10; 而且我必须在二进制表示中找到 x1 和 x2 之间的总和。 5 = 10
我有这个“程序集”文件(仅包含 directives ) // declare protected region as somewhere within the stack .equiv prot_s
有没有办法在powershell中确定指定的文件是否包含指定的字节数组(在任何位置)? 就像是: fgrep --binary-files=binary "$data" "$filepath" 当然,
我是一名工程师,而不是软件程序员,所以请原谅我的无知。 我编写了一个 Delphi(7SE) 程序,用于从连接到两个数字温度计的 USB 端口读取“真实”数据类型。 我已经完成了该计划的大部分内容。
我有一些代码,例如: u=(float *)calloc(n, sizeof(float)); for(i=1; i
typedef struct pixel_type { unsigned char r; unsigned char g; unsigned char b;
如何判断二进制数是否为负数? 目前我有下面的代码。它可以很好地转换为二进制文件。转换为十进制时,我需要知道最左边的位是否为 1 以判断它是否为负数,但我似乎无法弄清楚该怎么做。 此外,我如何才能让它返
我有一个带有适当重载的 Vect*float 运算符的 vector 类,我正在尝试创建全局/非成员 float*Vect 运算符,如下所示:(注意这是一个经过大量编辑的示例) class Vect
对于使用 C 编程的项目,我们正在尝试将图像转换为二进制数据,反之亦然。我们在网上找到的所有其他解决方案都是用 C++ 或 Java 编写的。这是我们尝试过的方法: 将图像转换为包含二进制数据的文本文
我需要对列表的元素求和,其中包含所有零或一,如果列表中有 1,则结果为 1,否则为 0。 def binary_search(l, low=0,high=-1): if not l: retu
我到处搜索以找到将 float 转换为八进制或二进制的方法。我知道 float.hex 和 float.fromhex。是否有模块可以对八进制/二进制值执行相同的工作? 例如:我有一个 float 1
当我阅读有关 list.h 文件中的 hlist 的 FreeBSD 源代码时,我对这个宏感到困惑: #define hlist_for_each_entry_safe(tp, p, n, head,
我不知道出了什么问题,也不知道为什么会出现此错误。我四处搜索,但我终究无法弄明白。 void print_arb_base(unsigned int n, unsigned int b) {
在任何语言中都可以轻松地将十进制转换为二进制,反之亦然,但我需要一个稍微复杂一点的函数。 给定一个十进制数和一个二进制位,我需要知道二进制位是开还是关(真或假)。 示例: IsBitTrue(30,1
在下面的代码中,我创建了两个文件,一个是文本格式,另一个是二进制格式。文件的图标显示相同。但是这两个文件的特征完全相同,包括大小、字符集(==二进制)和流(八位字节)。为什么没有文本文件?因为如果我明
我想通读一个二进制文件。谷歌搜索“python binary eof”引导我here . 现在,问题: 为什么容器(SO 答案中的 x)不包含单个(当前)字节而是包含一大堆字节?我做错了什么? 如果应
为什么只允许以 10 为基数使用小数点?为什么以下会引发语法错误? 0b1011101.1101 我输入的数字是否有歧义?除了 93.8125 之外,字符串似乎没有其他可能的数字 同样的问题也适用于其
boost 库中有二进制之类的东西吗?例如我想写: binary a; 我很惭愧地承认我曾尝试找到它(Google、Boost)但没有结果。他们提到了一些关于 binary_int<> 的内容,但我既
我是一名优秀的程序员,十分优秀!