mysql 插入16进制数据


  mysql 通过insert into 插入 16进制数据到库表 blob 数据列中。

  首先想到的是 通过转换函数 conv(1209,10,16) 将十进制的数据转为 16进制 写入blob列,但是由于conv 函数返回的是 转换之后的 字符串形式,也就是说,函数返回的实际上是 形如

"0x22c304" 这样的数据,blob是以二进制存储的,所以当使用这个函数转换 ,然后借助

insert into blob_test values(conv(1209,10,16)) 执行语句执行的时候,实际上相当于
insert into blob_test values("0x22c304") ;  插入之后,实际上是blob对 字符串"0x22c304" 进行二进制转储,变成了 13850772474184761,通过语句 select conv(hex(bc.datatimestamp) ,16,10) as datatimestamp from blob_test bc 查看,是无法正常显示为 1209 的。

同样的道理, cast 函数也是返回字符串形式,所以也无法完成任务。

这时候 可以通过 char(n) 函数操作,
  请尊重知识,请尊重原创 更多资料参考请见  http://www.cezuwang.com/listFilm?page=1&areaId=906&filmTypeId=1
insert into blob_test values(char(1209)) ;

插入数据库成功,然后通过 conv(hex(bc.datatimestamp)) from blob_test bc; 查看,正常显示为 1209,达到要求,通过。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

annan211

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

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值