免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2262 | 回复: 3

求教:Mysql 16进制字符串如何转换为blob? [复制链接]

论坛徽章:
1
申猴
日期:2013-09-09 10:22:56
发表于 2015-04-08 14:11 |显示全部楼层
现在表中有一个字段是blob类型的,假设为info, 通过hex(info)将其转换为16进制字符串,现在修改这个字符串中的一段数据后,想要写会原字段,unhex请教大神如何操作? unhex后写入后发现与原字段的数据不匹配。

比如 unhex( substr( hex(info), 1, 4) ), 写入后与原始字段的前4个字节不一致?

论坛徽章:
92
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2015-02-28 17:45:34CU大牛徽章
日期:2019-10-10 10:55:38ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:28CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2015-04-14 16:56 |显示全部楼层
回复 1# Carl01Zhang


    楼主的问题解决了吗?是啥原因?为啥我试不出来呢:
  1. mysql> select * from blobtest;
  2. +-----------------+
  3. | ttt             |
  4. +-----------------+
  5. | rtgfgdagw45reqr |
  6. | asdfdfasdf      |
  7. +-----------------+
  8. 2 rows in set (0.00 sec)

  9. mysql> select unhex( substr( hex(ttt), 1, 4) ) from blobtest;
  10. +----------------------------------+
  11. | unhex( substr( hex(ttt), 1, 4) ) |
  12. +----------------------------------+
  13. | rt                               |
  14. | as                               |
  15. +----------------------------------+
  16. 2 rows in set (0.00 sec)

复制代码

论坛徽章:
1
申猴
日期:2013-09-09 10:22:56
发表于 2015-04-15 13:46 |显示全部楼层
回复 2# seesea2517

这样select出来的结果当然是正确的;我的意思是要写会到原字段中


   

论坛徽章:
92
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2015-02-28 17:45:34CU大牛徽章
日期:2019-10-10 10:55:38ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:28CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2015-04-15 13:54 |显示全部楼层
回复 3# Carl01Zhang

看来我的rp比较好,没发现问题:
  1. mysql> select * from blobtest;
  2. +-----------------+
  3. | ttt             |
  4. +-----------------+
  5. | rtgfgdagw45reqr |
  6. | asdfdfasdf      |
  7. +-----------------+
  8. 2 rows in set (0.11 sec)

  9. mysql> select unhex( substr( hex(ttt), 1, 4) ) from blobtest;
  10. +----------------------------------+
  11. | unhex( substr( hex(ttt), 1, 4) ) |
  12. +----------------------------------+
  13. | rt                               |
  14. | as                               |
  15. +----------------------------------+
  16. 2 rows in set (0.00 sec)

  17. mysql> update blobtest set ttt = unhex( substr( hex(ttt), 1, 4) );
  18. Query OK, 2 rows affected (0.05 sec)
  19. Rows matched: 2  Changed: 2  Warnings: 0

  20. mysql> select * from blobtest;
  21. +------+
  22. | ttt  |
  23. +------+
  24. | rt   |
  25. | as   |
  26. +------+
  27. 2 rows in set (0.00 sec)

  28. mysql> show create table blobtest;
  29. +----------+--------------------------------------------------------------------
  30. -----------+
  31. | Table    | Create Table
  32.            |
  33. +----------+--------------------------------------------------------------------
  34. -----------+
  35. | blobtest | CREATE TABLE `blobtest` (
  36.   `ttt` blob
  37. ) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
  38. +----------+--------------------------------------------------------------------
  39. -----------+
  40. 1 row in set (0.00 sec)
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP