【问题标题】:MySQL Workbench shows results as BLOBMySQL Workbench 将结果显示为 BLOB
【发布时间】:2012-11-18 00:48:10
【问题描述】:

我一直发现 MySQL Workbench 将查询结果显示为 BLOB。例如: SELECT INET_NTOA(167773449) --> BLOB

如果我选择“查看值”,我可以确定文本值是“10.0.5.9”,但是当我选择多行并想看一眼内容时,这很烦人。

有没有办法解决这个问题,还是工具的限制?

【问题讨论】:

    标签: mysql mysql-workbench


    【解决方案1】:

    背景: 当结果中返回二进制字符串值(BINARY/VARBINARY 类型)时,会出现此问题。二进制字符串包含零字节,出于某种原因,显然是安全的,默认情况下没有显示。更多关于二进制字符串here的细节。

    即使在报告的示例SELECT INET_NTOA(167773449) 中,该函数也会返回二进制字符串。参考this

    解决方案: 从 MySQL Workbench v5.2.22 开始,可以通过首选项设置是否显示或隐藏这些值。

    1. 在 MySQL Workbench 中,转到:“编辑 -> 首选项... -> SQL 查询“编辑 -> 首选项... - > SQL 编辑器 -> SQL 执行"(取决于您拥有的 Workbench 版本)。
    2. 选中“将 BINARY/VARBINARY 视为非二进制字符串”选项以显示实际值。

    参考: 原始问题已报告并通过修复 here 进行了答复。

    【讨论】:

    • 在Workbench 6.2中,设置在Edit -> Preferences -> SQL Editor -> SQL Execution
    • 在 6.2 范围内的某个地方出现了回归:这不再有效。
    【解决方案2】:

    您可以做的是将您的 BLOB 类型转换为字符串。这只会让您在浏览您的选择语句时浏览一下您的 BLOB 类型中的内容。

    SELECT CAST(`blob_column_name` AS CHAR(10000) CHARACTER SET utf8) FROM `table_name`;
    

    【讨论】:

      猜你喜欢
      • 2014-09-04
      • 2018-04-26
      • 1970-01-01
      • 2011-02-06
      • 2018-02-08
      • 2018-03-29
      • 2011-01-09
      • 2015-05-04
      相关资源
      最近更新 更多