
1.server本身设定问题,例如还停留在latin1版本
2.table的语系设定问题(包含character与collation)
3.客户端程式(例如php,java)的连线语系设定问题
建议使用utf8!!!!
想要避免mysql的中文乱码问题,可以尝试以下方法:
1,对于版本问题,建议去官网更新最新的版本或者比较好用的版本;
2,创建数据库,创建表时没有对字符编码进行设定会造成乱码问题:
创建数据库的时候:CREATE DATABASE `test`
CHARACTER SET 'utf8'
COLLATE 'utf8_general_ci'
建表的时候 CREATE TABLE `database_user` (
`ID` varchar(40) NOT NULL default '',
`UserID` varchar(40) NOT NULL default '',
) ENGINE=InnoDB DEFAULT CHARSET=utf8
3,对于第三种情况,参考一下方法:
编辑linux服务器中/etc/my.cnf文件,在[mysql]段加入default_character_set=utf8
如果只是调试遇到乱码问题:
在编写Connection URL时,加上?useUnicode=true&characterEncoding=utf-8参数
并且在网页代码中加上一个"set names utf8"或者"set names gbk"的指令,告诉MySQL连线内容都要使用utf-8或者gbk。
utf8或者gbk
一: 通过增加参数 –default-character-set = utf8 解决乱码问题
mysql -u root -p password <path_to_import_file –default-character-set = utf8
方法二: 在命令行导入乱码解决
1. use database_name
2. set names utf8(或其他需要的编码)
3. source example.sql (sql文件存放路径)
方法三: 直接粘贴sql文件里的代码
1. 打开SQLyog客户端软件
2. 定位到SQL编辑器,然后用记事本打开刚刚导出的SQL文件
3. 复制文件中所有SQL语句到SQL编辑器当中,执行这些SQL代码
方法四: 用记事本或其他文本工具改变SQL文件的编码格式(若方法三不行,那就尝试方法四)
1. 用记事本(或UE)打开刚才的导出的SQL文件
2. 另存此文件——打开另存为对话框,选择对话框中的编码格式为UNICODE编码
3. 保存文件,然后CTRL+A,全选
4. 复制里面的SQL语句到SQLyog中的“SQL编码器”当中,再执行一次SQL语句
5. 执行完成后切记刷新一次,查看中文的数据表,乱码消除,大功告成
设置你的eclipse的编码方式在eclipse的属性里面设置编码方式为utf-8;设置你的filter的字符集,用setCharacterEncoding()进行页面的字符集设置;在连接数据库的时候连接词加上字符集转换jdbc:mysql://127.0.0.1:3306/db?useUnicode=true&characterEncoding=gbk&mysqlEncoding=utf-8
要你修改的是你的项目里面的web.xml里面的配置,不过这是在你在代码中设置了要去读取配置文件中的设置的编码方式。跟你修改mysql里面的关系不大
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)