將SQL Server字符串的整數(shù)轉(zhuǎn)換成16進(jìn)制
來(lái)源:程序員人生 發(fā)布時(shí)間:2014-05-11 18:08:27 閱讀次數(shù):3066次
今天,由于需要模擬一個(gè)RFID卡的過(guò)車記錄過(guò)程!其中有一個(gè)需要模擬RFID標(biāo)簽的!
由于RFID標(biāo)簽數(shù)量有限!而BOSS又要我一下搞30萬(wàn)條數(shù)據(jù)到數(shù)據(jù)庫(kù)中去(變態(tài))!RFID卡由16進(jìn)制組成。
于是在SQL Server中寫下了兩個(gè)關(guān)于16進(jìn)制轉(zhuǎn)換的函數(shù),以隨機(jī)的來(lái)生成所需RFID數(shù)據(jù):
/****************************
字符串轉(zhuǎn)成16進(jìn)制
作者:不得閑
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
/****************************
整數(shù)轉(zhuǎn)換成16進(jìn)制
作者:不得閑
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
具體使用,直接傳遞要轉(zhuǎn)換的信息進(jìn)去則可
如
Select Dbo.VarcharToHex('不得閑')
select Dbo.IntToHex(125)
轉(zhuǎn)自:http://www.cnblogs.com/DxSoft/
生活不易,碼農(nóng)辛苦
如果您覺(jué)得本網(wǎng)站對(duì)您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)