一个比较难的问题 高手来帮忙哈!

huang1204 2005-12-28 02:08:27

DECLARE @bin binary(128)
SELECT @bin = bin_set FROM UserInfo WHERE char_index = 50001
SET @bin = CONVERT(binary(128), STUFF(@bin, 70, 1, 0x02))
UPDATE UserInfo SET bin_set= @bin WHERE set_index = 50001

这段代码的功能就是 修改binary格式字段中指定位置的某一个字节的数据,现在的问题就是这一句SET @bin = CONVERT(binary(128), STUFF(@bin, 70, 1, 0x02)),操作后得到的@bin是错误的,实际上修改的位置在70以后了, 因为他执行这一句操作的时候,中间把一些字符丢弃了
现在请问大家 还有什么办法能实现类似的功能 !
MS SQL的帮助文件说STUFF是支持binary,但是我操作binary时 返回的还是CHAR类型的数据!!

谢谢啊~!!~!~~!
...全文
148 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
huang1204 2005-12-28
  • 打赏
  • 举报
回复
改了下!!!!
declare @a binary(20),@b binary(20),@c binary(20)
set @a=0xa102a304a506a708a910a112a314
set @b=@a
set @c=@a
print @a
set @a=convert(binary(20),stuff(@a,10,1,0x02))
--set @b=cast(left(@b,9) as binary(9))+0x02+cast(right(@b,10) as binary(10))
set @b = cast(substring(@c,1,9) + 0x02 + substring(@c,11,10) as binary(20))
print @a
print @b
go


0xA102A304A506A708A910A112A314000000000000
0xA102A304A506A708A910A112A314000002000000
0xA102A304A506A708A902A112A314000000000000

这下就正确了 还是用substring来操作~
huang1204 2005-12-28
  • 打赏
  • 举报
回复
楼上的 有什么好办法没?
bobfang 2005-12-28
  • 打赏
  • 举报
回复
libin_ftsafe(子陌红尘) 的方法也有问题。
1> declare @a binary(20),@b binary(20)
2> set @a=0xa102a304a506a708a910a112a314
3> set @b=@a
4> print @a
5> set @a=convert(binary(20),stuff(@a,10,1,0x02))
6> set @b=cast(left(@b,9) as binary(9))+0x02+cast(right(@b,10) as binary(10))
7> print @a
8> print @b
9> go
(1 row affected)
(1 row affected)
0xA102A304A506A708A910A112A314000000000000
(1 row affected)
(1 row affected)
0xA102A304A506A708A910A112A314000002000000
0xA102A304A506A708A902A708A910A112A3140000
1>
huang1204 2005-12-28
  • 打赏
  • 举报
回复
谢谢 楼上的~!~!
子陌红尘 2005-12-28
  • 打赏
  • 举报
回复
SET @bin = cast(left(@bin,69) as binary(69))
+0x02
+cast(right(@bin,58) as binary(58))
huang1204 2005-12-28
  • 打赏
  • 举报
回复
那操作字节的 请问用什么函数呢?
子陌红尘 2005-12-28
  • 打赏
  • 举报
回复
STUFF()函数是针对字符操作而非字节操作的。

22,206

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧