在Transact-SQL语句中如何用常量来表示二进制形式的数据?

  二进制数据可能是图像、声音或任何其他数据。如果我们能够把这些二进制以常量的形式表示,我们就可以直接用Transcat-SQL语句来插入和更新数据表中的这些数据。
  其实,Transcat-SQL已经给我们提供了方法,那就是二进制常量格式。这个格式是以“0x”开头,后面跟若干十六进制数字,每个字节用两位十六进制数来表示。因此,你完全可以将那些图像声音数据转换成这种二进制常量格式,然后用于INSERT或UPDATE语句中。
  不过,这样的二进制常量将很长很长。这样一来SQL语句很难翻看,而且在某些行的长度有限制的编辑器中还会出问题。
  那么,又没有给二进制常量折行的办法呢?
  很遗憾,我查遍Transact-SQL的联机帮助,搜遍了网络,都没有答案。
  难道就真的没办法?
  路从来都是有人走过以后才能成其为路。也许前人曾经走过,而后人不知道。甚至,路本来就在那里,而你敢不敢走?
  于是,冒险开始:
  我将那个长长的二进制常量强行折断,执行,出错...
  在前面一行加“_”,VB的折行符号,出错...
  换成“/n”,C,C++字符串的折行符号,出错...
  用引号引起来,出错...
  换双引号,出错...
  ...,出错...
  ...,出错...
  ...,出错...
  前面一行就加“/”,成功!
  我有点不敢相信,再试,成功!

  稍微惊喜之后,我立刻保持冷静:插入的数据是否正确呢?
  立即,编写程序验证,完全正确!
  

  原来“/”是二进制常量的换行符,路就在那儿!

  但请注意:在INSERT和UPDATE语句中,用二进制常量最多能更新8000个字节的数据。如果需要,处理更大的数据,请用WRITETEXT语句或UPDATETEXT语句,并需要分段多次处理。

李战.深圳 2004-10-14
  • 0
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
评论 1

打赏作者

李战

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值