在数据库中,字符乱码属于常见、多发问题。鉴于本人水平顶多只能归于不入流之类,写这篇文章时内心诚惶诚恐,实在担心误导大家。内容仅供参考,若有错误,请各位及时指出,我也好学习提高!

MySQL的字符集有4种级别的设置,分别是:服务器级、数据库级、表级、字段级。

一、服务器级字符集

(1)、可以在my.cnf中设置

[mysqld]
default-character-set=gbk (5.1)
character-set-server=gbk (5.5)

(2)、可以在启动选项中设置

mysqld --default-character-set=gbk

(3)、可以在编译的时候设置

./configure --with-charset=gbk

cmake . -default-charset=gbk

如果没有指定服务器的字符集,默认使用latin1为服务器的字符集。

(4)、查看当前服务器的字符集

mysql> show variables like '%char%';
+--------------------------+-----------------------------------------+
| Variable_name | Value |
+--------------------------+-----------------------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql-5.6.28/share/charsets/ |
+--------------------------+-----------------------------------------+

二、数据库字符集

数据库的字符集在创建数据库的时候指定,也可以在创建完数据库之后通过alter database语句修改。如果数据库中已经存在数据,修改数据库字符集并不能将已有的数据按新字符集存放。所以无法通过修改数据库字符集修改数据的内容。

设置数据库字符集的规则:

(1)、如果指定了字符集和校对规则,则使用指定的规则;

(2)、如果仅指定字符集而没有指定校对规则,则使用指定的字符集和默认的校对规则;

(3)、如果没有指定字符集和校对规则,则使用服务器的字符集和校对规;

三、表字符集

表的字符集是在建表的时候指定的,可以通过alter table语句进行修改。同样,对于表中已经存在的数据,修改字符集不会影响原有的记录,仍将使用原有的字符集。

设置表的字符集的规则同设置数据库的字符集规则。

四、列字符集

列的字符集和校对规则可以在建表的时候指定,也可以在修改表的时候调整。(这个不常用,仅记录一下)

五、SET NAMES命令

除了上述的四种字符集外,对实际的应用访问来说,还存在客户端和服务端之间交互的字符集,如下:

(1)、character_set_client:客户端字符集
(2)、character_set_connection:连接字符集
(3)、character_set_resluts:结果字符集

通常情况下,这3个字符集都应该是相同的,才能保证用户写入的数据被正确的读出,特别是对于中文字符。

set names命令则用于同时修改这3个参数的值。

六、关于中文字符集插入的实验

字符集不一致是导致数据库内中文内容乱码的罪魁祸首。

实验环境:

Server version: 5.6.28 (在此说明实验环境是由于在学习过程中,从网上参考了部分资料,实验过程与资料描述稍有出入,未查出原因,只能暂归结为版本不同所致。)

实验对象:

mysql> show create table char_test\G
*************************** 1. row ***************************
Table: char_test
Create Table: CREATE TABLE `char_test` (
`id` smallint(6) NOT NULL AUTO_INCREMENT,
`name` char(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

由上可知,char_test表的字符集是latin1,如果不设置正确的字符集,插入中文字符时,必然会出现如下错误:

mysql> insert into char_test (name) values ('小王');
ERROR 1366 (HY000): Incorrect string value: '\xE5\xB0\x8F\xE7\x8E\x8B' for column 'name' at row 1

解决方案

(1)、先set names latin1,然后再插入数据。

mysql> set names latin1;
Query OK, 0 rows affected (0.00 sec) mysql> insert into char_test (name) values ('小王');
Query OK, 1 row affected (0.01 sec) mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
+----+--------+
3 rows in set (0.00 sec)

(2)、在data.sql文件中指定set names latin1,然后通过source命令导入data.sql。

# vi data.sql
set names latin1;
insert into char_test (name) values ('小李'); mysql> source data.sql
Query OK, 1 row affected (0.00 sec) mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
| 4 | 小李 |
+----+--------+
4 rows in set (0.00 sec)

(3)、在data.sql文件中指定set names latin1,然后通过mysql命令导入

# vi data.sql
set names latin1;
insert into char_test (name) values ('小张'); # mysql -uroot -p test1 < data.sql
# mysql -uroot -p -e "set names latin1;select * from test1.char_test;"

(4)、通过指定mysql命令的字符集参数实现 --default-charset-set=字符集

# vi data.sql
insert into char_test (name) values ('小张'); # 错误方法
# mysql -uroot -p test1 < data.sql
Enter password: ******
ERROR 1366 (HY000) at line 1: Incorrect string value: '\xE5\xB0\x8F\xE8\xB5\xB5' for column 'name' at row 1 # 正确方法
# mysql -uroot -p --default-character-set=latin1 test1 < data.sql
Enter password: ****** # mysql -uroot -p -e "set names latin1;select * from test1.char_test;"
Enter password: ******
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
| 4 | 小李 |
| 5 | 小张 |
| 6 | 小赵 |
+----+--------+

(5)、在配置文件中指定客户端的字符集

vi my.cnf
[client]
default-character-set=latin1 mysql> insert into char_test (name) values ('小马');
Query OK, 1 row affected (0.00 sec) mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
| 4 | 小李 |
| 5 | 小张 |
| 6 | 小赵 |
| 7 | 小马 |
+----+--------+
7 rows in set (0.00 sec)

了解MySQL的字符集的更多相关文章

  1. 修改MySQL默认字符集编码

    好记心不如烂笔头,很多东西当时没记下来,过了就忘了,下次用到时又得浪费好多时间才能解决.今天又遇到修改MySQL默认字符集编码的问题,折腾了半天解决了,赶快记录下来,以后就不用每次折腾了. 查看MyS ...

  2. MySQL设置字符集为UTF8(Windows版)

    Windows版MySQL设置字符集全部为utf8的方式 MySQL安装目录下的my.ini文件 [client]节点 default-character-set=utf8    (增加) [mysq ...

  3. 修改mysql默认字符集的方法

    +--------------------------+---------------------------------+ | Variable_name | Value | +---------- ...

  4. MySQL的字符集

    MySQL的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation). 字符(Character)是指人类语言中最小的表 ...

  5. 修改mysql默认字符集的方案

    mysql默认字符集能否进行修改呢?答案是肯定的,下面就将教您两种修改mysql默认字符集的方法,希望对您学习mysql默认字符集方面能有所启迪. (1) 最简单的修改方法,就是修改mysql的my. ...

  6. mysql默认字符集修改

    (1) 最简单的修改方法,就是修改mysql的my.ini文件中的字符集键值,添加 [mysql] default-character-set = utf8 [mysqld] character_se ...

  7. 【转】MYSQL入门学习之五:MYSQL的字符集

    转载地址:http://www.2cto.com/database/201212/175541.html MySQL的字符集支持(Character Set Support)有两个方面:字符集(Cha ...

  8. mysql之字符集与校对集

    一.字符集 1.mysql的字符集设置非常灵活 可以设置服务器默认字符集: 数据库默认字符集: 表默认字符集: 列字符集: 如果某一级别没有指定字符集,则继承上一级. 查看所有字符集语句:show c ...

  9. 完美转换MySQL的字符集 Mysql 数据的导入导出,Mysql 4.1导入到4.0

    MySQL从4.1版本开始才提出字符集的概念,所以对于MySQL4.0及其以下的版本,他们的字符集都是Latin1的,所以有时候需要对mysql的字符集进行一下转换,MySQL版本的升级.降级,特别是 ...

  10. mysql修改字符集 转载

    查看编码:    show variables like 'collation_%';    show variables like 'character_set_%';    修改:    MySQ ...

随机推荐

  1. java Beanutils.copyProperties( )用法

    这是一篇开发自辩甩锅稿~~~~ 昨天测试小姐姐将我的一个bug单重开了,emmmm....内心OS:就调整下对象某个属性类型这么简单的操作,我怎么可能会出错呢,一定不是我的锅!!but再怎么抗拒,bu ...

  2. css & no margin & print pdf

    css & no margin & print pdf no header & no footer https://stackoverflow.com/questions/46 ...

  3. vue.js编程式路由导航 --- 由浅入深

    编程式路由导航 实例中定义一个方法,这个方法绑定在标签上 然后就设置路由跳转 语法 this.$router.history.push('要跳转路由的地址') <!DOCTYPE html> ...

  4. 测试出来了第一版代码--可以得到用户token啦

    一版一版往前走啦... 先安装vs2010的学习版, 然后用codeblock来搞. 有一个msvcr100.dll这个文件需要和代码同级目录. 这样的好处是合规,然后,codeblock也可以用vs ...

  5. BZOJ(2) 1041: [HAOI2008]圆上的整点

    1041: [HAOI2008]圆上的整点 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4966  Solved: 2258[Submit][Sta ...

  6. Ubuntu 16.04在启动和关机时不显示启动和关机画面且显示详细的命令信息,没有进度条和Logo,或者只有紫色界面,或者没有开机画面等问题解决

    主要有以下解决方法: 1.如果之前配置过Grub来显示详细的命令信息的,那么改回去就行了,参考:http://www.cnblogs.com/EasonJim/p/7129873.html,通过这种方 ...

  7. MySQL大小写问题的简单说明(关键字/函数/表名)(转)

    MySQL语句中字母大小写规则随着语句元素的不同而变化,同时还要取决于MySQL服务器主机上的操作系统. SQL关键字与函数名 关键字和函数名不区分字母的大小写.如.abs.bin.now.versi ...

  8. RESTFUL 和SOA初探

    这篇文章是转载的,restful简单的说就是url明确的指向资源.soa还不好用自己的话解释,但明显不是这样,好吧,我自己的理解就是soa就是访问网站的一个接口.以访问一个blog list为例子,  ...

  9. ubuntu 图形界面搜索软件Catfish (鲶鱼)

    Catfish(鲶鱼)是一款Linux桌面图形软件,可以在桌面图形化的搜索文件. 在Ubuntu下可以用 : sudo apt-get install catfish 安装

  10. Office 如何打印A4不干胶标签纸

    1 下载Label Expert这个软件,注意不是第一个Avery Wizard(卖家可能会送你这个软件,但是送的这款软件是简体中文版的,似乎模板不全,所以最好还是自己下,反正我最后是由于找不到对应的 ...