前言: 一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集) 保证不出现乱码的思想:保证客户端、服务端
一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)
保证不出现乱码的思想:保证客户端、服务端、数据库、表字符集统一
坑:有的时候,cmd或者linux系统字符集问题,其实数据库是正确的,只是我们执行命令在终端看到的是乱码而已,这时需要设置linux系统字符集
1、查看liunx系统字符集:cat /etc/sysconfig/i18n
2、vim /etc/sysconfig/i18n
备注:始终牢记,存放数据的是字段,所以编码最后是以字段的编码为准,数据库和表的编码影响的时候字段的默认值,也就是说在设置了数据库编码之后,新建的表在不指定的情况下就会和数据库编码相同,而不指定字段的编码时,字段的编码和表相同。如果使用 Alter 修改一个表的字符编码,那原来的字段编码并不会发生改变,如果需要修改表编码的同时修改字段的编码,可以使用 convert
show create database Django\G (djanGo 是数据库名称)
show create table auth_group\G (auth_group 是表名称)
ENGINE = InnoDB 该表数据库引擎是InnoDB
DEFULT CHARSET=utf8 该表字符集是utf8
COLLATE utf8_general_ci 校准规则
show character set;
eg:如果数据库表字符集是latinl,那么插入数据的时候也要是latinl
方法:set names latinl
insert into student value('飞东')
方法:将下面两个语句放入一个新建文件中,如Mysql.sql
set names Latinl
insert into student value('飞东')
执行这个文件:source mysql.sql
将数据编码格式保存为utf-8(UTF8不要导入gbk,gbk不要导入UTF8)
set names utf8;
ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci; 修改数据库的编码格式
ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci; 修改表的编码格式
LOADLOCAL'C:\\utf8.txt'INTOTABLE tb_name; 从文件中导入数据库
修改完毕之后重启mysqld服务:service mysqld restart
character_set_client(客户端)、character_set_connection(连接)、character_set_results(结果) 三者字符集是一致的
ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;
ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;
4、建议表语句:
--结束END--
本文标题: MySQL--字符编码和字符集
本文链接: https://www.lsjlt.com/news/35007.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-28
2024-04-28
2024-04-28
2024-04-28
2024-04-28
2024-04-28
2024-04-26
2024-04-26
2024-04-26
2024-04-26
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0