我有很多记录,其中文本被存储在MySQL中的blob中。为了方便处理,我想改变数据库的格式为文本…有什么想法可以轻松地进行更改,从而不中断数据-我猜它将需要正确编码?
当前回答
下面是一个想用UTF-8编码将一个blob转换为char(1000)的例子:
CAST(a.ar_options AS CHAR(10000) CHARACTER SET utf8)
这是他的答案。你可以在这里读到更多关于CAST的内容。我希望这能有所帮助。
其他回答
如果您使用的是MYSQL-WORKBENCH,那么您可以正常地选择blob列,然后右键单击列,然后在编辑器中单击打开值。请参考截图:
下面是一个想用UTF-8编码将一个blob转换为char(1000)的例子:
CAST(a.ar_options AS CHAR(10000) CHARACTER SET utf8)
这是他的答案。你可以在这里读到更多关于CAST的内容。我希望这能有所帮助。
使用phpMyAdmin,您还可以设置选项来显示BLOB内容和显示完整的文本。
这是不必要的。只需使用SELECT CONVERT(column USING utf8) FROM.....而不是只是SELECT column FROM…
这些答案对我都没用。当转换为UTF8时,当编码器遇到一组字节它不能转换为UTF8它将导致一个?导致数据丢失的替换。你需要使用UTF16:
SELECT
blobfield,
CONVERT(blobfield USING utf16),
CONVERT(CONVERT(blobfield USING utf16), BINARY),
CAST(blobfield AS CHAR(10000) CHARACTER SET utf16),
CAST(CAST(blobfield AS CHAR(10000) CHARACTER SET utf16) AS BINARY)
您可以在MySQL Workbench中检查二进制值。右击字段->在查看器中打开值->二进制。当转换回二进制时,二进制值应该与原始值相同。
或者,你也可以使用base-64,这是为了这个目的:
SELECT
blobfield,
TO_BASE64(blobfield),
FROM_BASE64(TO_BASE64(blobfield))
推荐文章
- 在Mac上安装MySQL后,使用ALTER USER语句重置MySQL root密码
- 在postgresql中将查询结果按月和年分组
- my.cnf文件在macOS上的位置
- 索引中列的顺序有多重要?
- 如何从Mac OS X上卸载MySQL ?
- 在SQL Server中做嵌套case语句逻辑的最佳方法
- 如何创建默认值“现在”的时间戳列?
- 如何在Docker容器中用模式初始化MySQL数据库?
- MySQL:如何重置或修改MySQL root密码?
- 如何从对象URL获取文件或blob ?
- 准备好的语句如何防止SQL注入攻击?
- 如何改变一个列的数据类型在PostgreSQL表?
- 在PHP中插入MySQL时转义单引号
- 如何结合日期从一个字段与时间从另一个字段- MS SQL Server
- 我如何得到“id”后插入到MySQL数据库与Python?