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) 函数操作,

insert into blob_test values(char(1209)) ;

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

你可能感兴趣的:(sql,mysql,server,数据挖掘)