如果将image字段数据转换成二进制

Changefish 2008-12-29 06:00:56
image字段用16进制存储数据,想转成二进制的字符串,该怎么转?谢谢
...全文
97 点赞 收藏 4
写回复
4 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
dawugui 2008-12-30
以下为16进制转10进制的函数,自己参考一下,然后更改.
CREATE FUNCTION dbo.f_hex_dec(@s varchar(16))
RETURNS bigint
AS
BEGIN
--作者:pbsql
--参数不得含'0'~'9'、'a'~'f'、'A'~'F'之外的任意字符(首尾空格除外),否则返回0
DECLARE @i int,@result bigint
SELECT @i=0,@result=0,@s=RTRIM(LTRIM(UPPER(REVERSE(@s))))
WHILE @i<LEN(@s)
BEGIN
IF SUBSTRING(@s,@i+1,1) not between '0' and '9' and SUBSTRING(@s,@i+1,1) not between 'A' and 'F'
BEGIN
SELECT @result=0
break
END
SELECT @result=@result+(CHARINDEX(SUBSTRING(@s,@i+1,1),'0123456789ABCDEF')-1)*POWER(16,@i),@i=@i+1
END
RETURN @result
END
GO
回复
dawugui 2008-12-30
[Quote=引用楼主 Changefish 的帖子:]
image字段用16进制存储数据,想转成二进制的字符串,该怎么转?谢谢
[/Quote]
16进制中如果含有2,3,...,a,b,c,d,e,f,不能转换为2进制.
回复
wsh236 2008-12-30
能不能先转化成text 然后在转化成二进制
/*--示例说明:
下面的代码演示了转换pubs数据库的pub_info表中的pr_info列(text类型)为image类型
及将转换结果再转换为text的处理。
--*/
USE pubs

--创建一个临时表,用来转换 pub_info.pr_info 列值
CREATE TABLE #t(id int,a image,b text)
GO

--将 pub_info.pr_info 转换到 #t.a 列中
DECLARE @id int,@ps binary(16),@pd binary(16)
DECLARE tb CURSOR LOCAL
FOR
SELECT pub_id,TEXTPTR(pr_info) FROM pub_info
WHERE TEXTVALID('pub_info.pr_info',TEXTPTR(pr_info))=1
OPEN tb
FETCH tb INTO @id,@ps
WHILE @@FETCH_STATUS=0
BEGIN
INSERT #t VALUES(@id,0x,'')
SELECT @pd=TEXTPTR(a) FROM #t
WHERE TEXTVALID('#t.a',TEXTPTR(a))=1
IF @@ROWCOUNT>0
UPDATETEXT #t.a @pd 0 NULL pub_info.pr_info @ps
FETCH tb INTO @id,@ps
END
CLOSE tb
DEALLOCATE tb
GO

--将 #t.a 转换到 #t.b 列中
DECLARE @ps binary(16),@pd binary(16)
DECLARE tb CURSOR LOCAL
FOR
SELECT TEXTPTR(a),TEXTPTR(b) FROM #t
WHERE TEXTVALID('#t.a',TEXTPTR(a))=1
AND TEXTVALID('#t.b',TEXTPTR(b))=1
OPEN tb
FETCH tb INTO @ps,@pd
WHILE @@FETCH_STATUS=0
BEGIN
UPDATETEXT #t.b @pd 0 NULL #t.a @ps
FETCH tb INTO @ps,@pd
END
CLOSE tb
DEALLOCATE tb
GO

--显示转换结果
SELECT * FROM #t
DROP TABLE #t
回复
mathsfan 2008-12-29
不会,UP...
回复
发帖
应用实例
创建于2007-09-28

2.7w+

社区成员

MS-SQL Server 应用实例
申请成为版主
帖子事件
创建了帖子
2008-12-29 06:00
社区公告
暂无公告