关于mysql乱码问题的天坑

2024-03-02 10:32

本文主要是介绍关于mysql乱码问题的天坑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

搞了个基于Mysql的web应用,一开始只是展示数字,中文字典信息,没有什么问题。后面增加了用户录入中文,就出现了乱码。搞了两个晚上,踩坑无数,下面把心路历程罗列一下,算是个总结。

1.先查看了mysql编码相关的知识,知道mysql编码分的很细致,有基于服务器的,操作系统的,数据库的,表的,字段的。在读取的时候,又有基于connection的,result的。最终存储在磁盘file上,只有一种就是binary,二进制文件。

2.最好的办法,当然是把各个环节的字符编码都设置成一样的,一般来说utf8比较好。好的,请注意,坑来了!

3.第一坑,我当时安装的解压版,没有设置字符集这个环节,根据网上各种帖子设置my-default.ini都只能改到这个程度:

character_set_clientutf8
character_set_connection utf8
character_set_database utf8
character_set_filesystem BINARY
character_set_results utf8
character_set_server latin1
character_set_system utf8

也就是说character_set_server这一个还是不行,而且latin1是拉丁文编码,无论如何都兼容不了中文的。如上所述,整个环节中只要有一个出现乱码,后面就乱的回不来了。

4.第二坑,网上各种修改my.ini,my-default.ini都是改不了character_set_server的,虽然可以在命令行通过setcharacter_set_server=utf8,但是这是基于session的修改,关了之后就没了。

5.第三坑,比较靠谱的办法是,运行bin/MySQLInstanceConfig.exe,重新配置数据库设置。但是,回到第一坑,解压版,没有这个工具。

6.第四坑,好吧,我下一个安装版吧,只找得到最新版的安装版,并不能解决当前版本的问题。如果安装过程出问题,要影响应用的运行,我已经不想在这个问题上走这么远了。

20171012修订:在mysql的官网,是提供了安装版和解压版下载的,不知道当时写这篇博客的时候怎么就没看到。贻笑大方了。好在我是菜鸡,没有偶像包袱,啦啦啦啦啦。所以,我计划的解决方案是,使用安装版重新安装数据库。如果顺利解决,会再来更新。当然,或许会踩进更多地坑里。。。

20171020修订:安装版安装后,编码终于理顺了。

20190513修订:不管是安装版还是解压版,数据库文件都不在安装目录,而是在programData目录下,对应的配置文件也在那里。

7.绕了一圈,数据库端彻底解决问题的思路和办法都有,只是当前环境下不好实施。

8.最终解决办法:客户端为了把中文传输到Java后台用encodeURI对前段输入进行编码,后台直接存到表字段中;前台展示时,使用decodeURI解码。“完美”!

 

这篇关于关于mysql乱码问题的天坑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/765819

相关文章

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库