将SQL Server字符串的整数转换成16进制
发布时间:2020-12-12 12:36:07 所属栏目:MsSql教程 来源:网络整理
导读:今天,由于需要模拟一个RFID卡的过车记录过程!其中有一个需要模拟RFID标签的! 由于RFID标签数量有限!而BOSS又要我一下搞30万条数据到数据库中去(变态)!RFID卡由16进制组成。 于是在SQL Server中写下了两个关于16进制转换的函数,以随机的来生成所需RFID数据
今天,由于需要模拟一个RFID卡的过车记录过程!其中有一个需要模拟RFID标签的! 由于RFID标签数量有限!而BOSS又要我一下搞30万条数据到数据库中去(变态)!RFID卡由16进制组成。 于是在SQL Server中写下了两个关于16进制转换的函数,以随机的来生成所需RFID数据: /****************************字符串转成16进制 作者:不得闲 QQ: 75492895 Email: appleak46@yahoo.com.cn ****************************/ Create Function VarCharToHex(@Str Varchar(400)) returns varchar(800) as begin declare @i int,@Asi int,@ModS int,@res varchar(800),@Len int,@Cres varchar(4),@tempstr varbinary(400) select @i = 1,@res='',@len=datalength(@str),@tempStr = Convert(varbinary,@str) while @i<=@len begin Select @Asi = substring(@tempstr,1,1),@Cres='' while @Asi <> 0 begin select @Mods = @Asi %16, @Cres=Case when (@Mods > 9) then Char(Ascii('A')+@Mods-10)+@Cres else Cast(@Mods as varchar(4)) + @Cres end, @Asi = @Asi/16 end Select @res = @res + @Cres,@tempStr = substring(@tempStr,2,@len-1),@i = @i+1 end return @res end /**************************** 整数转换成16进制 作者:不得闲 QQ: 75492895 Email: appleak46@yahoo.com.cn ****************************/ Create Function IntToHex(@IntNum int) returns varchar(16) as begin declare @Mods int,@res varchar(16) set @res='' while @IntNum <> 0 begin set @Mods =@IntNum % 16 if @Mods > 9 set @res = Char(Ascii('A')+@Mods-10)+@res else set @res = Cast(@Mods as varchar(4)) + @res set @IntNum = @IntNum/16 end return @res end
具体使用,直接传递要转换的信息进去则可 如 Select Dbo.VarcharToHex('不得闲') select Dbo.IntToHex(125) 转自:http://www.cnblogs.com/DxSoft/ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |