mysql 插入16进制数据 博客分类: mysql mysqlSQL Server数据挖掘
程序员文章站
2024-03-22 20:21:40
...
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,达到要求,通过。
推荐阅读
-
mysql 插入16进制数据 博客分类: mysql mysqlSQL Server数据挖掘
-
MySQL常用SQL及命令 博客分类: 数据库 mysqlsql命令
-
MySQL常用SQL及命令 博客分类: 数据库 mysqlsql命令
-
mysql千万级数据库插入速度和读取速度的调整记录(转) 博客分类: 数据库
-
mysql千万级数据库插入速度和读取速度的调整记录(转) 博客分类: 数据库
-
MySQL触发器 博客分类: 数据库 mysqlsql servertrigger
-
MySQL触发器 博客分类: 数据库 mysqlsql servertrigger
-
mysql 删除重复记录 保留一条 博客分类: 数据库 mysqlsql
-
MySQL存储程序开发最佳实践 博客分类: Database MySQLSQL数据结构
-
MySQL5数据库指令 博客分类: 数据库 MySQLSQL工作