博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server下字符串,整数转换成16进制字符串的方法
阅读量:4149 次
发布时间:2019-05-25

本文共 1452 字,大约阅读时间需要 4 分钟。

  今天,由于需要模拟一个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)asbegin  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 @resend/****************************   整数转换成16进制  作者:不得闲  QQ: 75492895  Email: appleak46@yahoo.com.cn****************************/Create Function IntToHex(@IntNum int)returns varchar(16)asbegin  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 @resend
 
具体使用,直接传递要转换的信息进去则可
Select Dbo.VarcharToHex('不得闲')
select Dbo.IntToHex(125)

转载地址:http://zesti.baihongyu.com/

你可能感兴趣的文章
来玩下go的http get
查看>>
队列和栈的本质区别
查看>>
matlab中inline的用法
查看>>
如何用matlab求函数的最值?
查看>>
Git从入门到放弃
查看>>
java8采用stream对集合的常用操作
查看>>
EasySwift/YXJOnePixelLine 极其方便的画出真正的一个像素的线
查看>>
Ubuntu系统上安装Nginx服务器的简单方法
查看>>
Ubuntu Linux系统下apt-get命令详解
查看>>
ubuntu 16.04 下重置 MySQL 5.7 的密码(忘记密码)
查看>>
Ubuntu Navicat for MySQL安装以及破解方案
查看>>
HTTPS那些事 用java实现HTTPS工作原理
查看>>
oracle函数trunc的使用
查看>>
MySQL 存储过程或者函数中传参数实现where id in(1,2,3,...)IN条件拼接
查看>>
java反编译
查看>>
Class.forName( )你搞懂了吗?——转
查看>>
jarFile
查看>>
EJB3.0定时发送jms(发布/定阅)方式
查看>>
EJB与JAVA BEAN_J2EE的异步消息机制
查看>>
数学等于号是=那三个横杠是什么符
查看>>