【发布时间】:2012-11-18 00:48:10
【问题描述】:
我一直发现 MySQL Workbench 将查询结果显示为 BLOB。例如:
SELECT INET_NTOA(167773449) --> BLOB
如果我选择“查看值”,我可以确定文本值是“10.0.5.9”,但是当我选择多行并想看一眼内容时,这很烦人。
有没有办法解决这个问题,还是工具的限制?
【问题讨论】:
标签: mysql mysql-workbench
我一直发现 MySQL Workbench 将查询结果显示为 BLOB。例如:
SELECT INET_NTOA(167773449) --> BLOB
如果我选择“查看值”,我可以确定文本值是“10.0.5.9”,但是当我选择多行并想看一眼内容时,这很烦人。
有没有办法解决这个问题,还是工具的限制?
【问题讨论】:
标签: mysql mysql-workbench
背景: 当结果中返回二进制字符串值(BINARY/VARBINARY 类型)时,会出现此问题。二进制字符串包含零字节,出于某种原因,显然是安全的,默认情况下没有显示。更多关于二进制字符串here的细节。
即使在报告的示例SELECT INET_NTOA(167773449) 中,该函数也会返回二进制字符串。参考this。
解决方案: 从 MySQL Workbench v5.2.22 开始,可以通过首选项设置是否显示或隐藏这些值。
参考: 原始问题已报告并通过修复 here 进行了答复。
【讨论】:
Edit -> Preferences -> SQL Editor -> SQL Execution下
您可以做的是将您的 BLOB 类型转换为字符串。这只会让您在浏览您的选择语句时浏览一下您的 BLOB 类型中的内容。
SELECT CAST(`blob_column_name` AS CHAR(10000) CHARACTER SET utf8) FROM `table_name`;
【讨论】: