MySQL命令无法输入中文问题的解决方式
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《MySQL命令无法输入中文问题的解决方式》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~
发现问题
近期通过 mysql 命令连接 mysql server 的时候, 出现了不能输入中文的现象, 如下所示:
mysql> SELECT 'Chinese characters are stripped'; +------------------------------------+ | Chinese characters are stripped | +------------------------------------+ | Chinese characters are stripped | +------------------------------------+ 1 row in set (0.00 sec)
输入的所有中文都会被替换为空. 上述测试为官方的 mysql-5.7.32 版本.
遍历官方 mysql 的 changelog-5.7.34 发现了 oracle 官方的 mysql-5.7.34 和 mysql-8.0.24 分别修复了以下 bug
For builds compiled using the libedit library, if the mysql client was invoked
with the --default-character-set=utf8 option, libedit rejected input of
multibyte characters. (Bug #32329078, Bug #32583436, Bug #102806)
参考bug-102806 , 出现和描述中类似的事情, mysql 命令行的交互模式不支持所有宽字符的输入.
不能输入中文会出现什么问题?
从测试来看, 该 bug 只影响通过 mysql 命令以交互模式连接 mysql server 的会话操作 . 如果线上有使用此 bug 的版本, 操作表的时候可能会出现丢失中文的问题.
以下方式不受影响:
1. 各程序通过相关驱动连接数据库;
2. mysql 命令以非交互模式操作, 比如 mysql -h ... -p....
哪些版本受影响
该 bug 在 5.7.34 和 8.0.24 中修复, 见 github-mysql-patch-117fb2 . 从修复的补丁来看, bug 与 libedit 版本没有关系, 不管是 rpm, deb 还是官方的 build 版本都受此影响.
从我们的测试来看, 以下版本都会受到影响:
5.7.31 ~ 5.7.33
8.0.21 ~ 8.0.23
备注: 其它发行版暂不明确, 大概率也会出同样的问题, 不过发行版通常比官方的慢一拍, 其低版本可能会提前修复该问题.
如何处理
线上的版本的选择可以集中在使用过的一些版本, 比如笔者常用的:
- percona 分支 percona-5.6.45 percona-5.7.28 percona-8.0.22 - 官方版本 mysql-5.6.29 mysql-5.7.28 mysql-8.0.19
如果线上已经使用了上述受影响的版本, 可以采用以下方式处理:
临时处理
不方便升级的话, 可以先使用 5.7.30 以下或 5.7.34 及以上版本的 mysql client 命令;
小版本升级
如果方便进行小版本升级, 建议升级到以下版本:
5.7.35
8.0.26
总结
终于介绍完啦!小伙伴们,这篇关于《MySQL命令无法输入中文问题的解决方式》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!
Mysql数据库的主从同步配置
- 上一篇
- Mysql数据库的主从同步配置
- 下一篇
- 一文带你了解Mysql主从同步原理
-
- 等待的超短裙
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享技术文章!
- 2023-02-28 22:32:25
-
- 轻松的狗
- 赞 ??,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章内容!
- 2023-02-12 13:17:36
-
- 淡定的衬衫
- 这篇文章出现的刚刚好,细节满满,很好,mark,关注老哥了!希望老哥能多写数据库相关的文章。
- 2023-02-11 22:37:28
-
- 火星上的月亮
- 这篇技术贴出现的刚刚好,好细啊,赞 ??,收藏了,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-02-03 08:34:18
-
- 暴躁的含羞草
- 细节满满,收藏了,感谢作者的这篇技术文章,我会继续支持!
- 2023-01-31 00:18:15
-
- 哭泣的铅笔
- 好细啊,mark,感谢楼主的这篇文章,我会继续支持!
- 2023-01-10 12:55:12
-
- 数据库 · MySQL | 2天前 | MySQL · 慢查询 · 索引优化 · COUNT查询 · 汇总表 · 联合索引 覆盖索引 汇总表 MySQL COUNT慢 COUNT(*)优化
- MySQL COUNT(*) 总数查询变慢怎么办:从扫描行数到汇总表的完整治理流程
- 329浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 455次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 468次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 439次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 608次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 591次使用
-
- GoLand如何设置中文
- 2022-12-30 105浏览
-
- golang json编码输出中文
- 2023-01-26 298浏览
-
- Go 验证字符串中是否包含中文(推荐)
- 2023-01-07 223浏览
-
- MySQL命令行方式进行数据备份与恢复
- 2023-01-07 416浏览
-
- 彻底解决MySQL使用中文乱码的方法
- 2022-12-28 414浏览

