拨开字符编码的迷雾--MySQL数据库字符编码
拨开字符编码迷雾系列文章链接:
1. MySQL字符集和校对规则
MySQL的字符集是用来定义MySQL存储字符串的方式,校对规则(有的软件叫排序规则)则是用来定义了比较字符串的方式。字符集和校对规则是一对多的关系。每种字符集都有一个默认校对规则。
查看数据库支持的字符集:
# 方法1:
SHOW CHARACTER SET;
# 方法2:
USE information_schema;
SELECT * FROM CHARACTER_SETS;
查看数据库支持的校对规则:
# 方法1:
SHOW COLLATION;
# 方法2:
USE information_schema;
SELECT * FROM collations;
2. MySQL各个级别字符集
MySQL可以对如下字符集进行设置:
- 服务器级字符集(CHARACTER_SET_SERVER)
- 数据库级字符集(CHARACTER_SET_DATABASE)
- 表级字符集
- 字段级字符集
- 连接字符集(CHARACTER_SET_CONNECTION),客户端连接数据库所用的字符集。
- 结果字符集(CHARACTER_SET_RESULTS),存储查询结果(含错误信息)所用的字符集。
- 客户端字符集(CHARACTER_SET_CLIENT),客户端发送给MySQL服务器的查询语句字符集。
- 系统字符集(CHARACTER_SET_SYSTEM),用于存储我们新建的或自带的数据库的表、列的名称,默认是UTF-8
服务器级、数据库级、表级、字段级 这4个字符集设置影响到数据库中存储数据的编码。 这4个级别的字符集继承关系为:服务器级 --> 数据库级 --> 表级 --> 字段级, 从左到右,一级继承一级,和C++、Java中的类的继承类似,如果某一级未显式的指定字符集,那么将继承上一级的字符集设置。
2.1 服务器级别字符集设置
服务器级别的字符集可以从下面几个地方指定,从上到下优先级依次增加:
- 编译MySQL时指定的字符集
- my.cnf配置文件设置character-set-server
- mysqld服务启动命令行中指定字符集
影响数据存储的字符集之间的关系:

查看当前数据库的字符集设置:
# 方法1:
SHOW VARIABLES LIKE '%character%';
# 方法2:
USE information_schema;
SELECT * FROM GLOBAL_VARIABLES WHERE VARIABLE_NAME LIKE '%character%';
3. utf8与utf8mb4区别
UTF-8是多字节编码方案,采用1~4个字节来存储一个字符,但在MySQL设计之初,一个字符最多采用3个字节的就可以存储,所以Mysql的设计者将MySQL中的UTF-8字符集(UTF-8其实不是字符集,是字符编码方案,但在MySQL中一直这么叫)设计成了最大长度只能为3. 如图:

但随着Unicode字符集的扩张,出现了需要4个字节才能存储的字符,如果这时仍然使用utf-8(指mysql中的3字节utf-8)来存储这些字符就会出现错误, 由于MySQL编码原因会导致数据库出现乱码. 解决办法: 修改MySQL数据库字符编码为UTF-8,UTF-8包含全世界所有国家需要用到的字符,是国际编码. 具体操作: 1.进入MySQL控制台 &g ... mysql数据库字符编码修改 修改数据库的字符集mysql>use mydb mysql>alter database mydb character set utf8; 创建数据库指定数据 ... MySQL数据库字符集和整理(2009-11-20 22:23:37) mysql数据库 it 其实这个表在MySQL数据库中通过phpMyAdmin就能看到,icech只是把表格整理了一下方便 ... MySQL数据库字符集和排序规则有四个级别的默认设置:服务器,数据库,表和列. 最初,服务器字符集和排序规则取决于启动mysqld时使用的选项.可以使用 --character-set-server该 ... mac 设置 MySQL 数据库默认编码(字符集)为 UTF-8 原文链接:https://juejin.im/post/5bbdca76e51d45021147de44 鉴于有些刚接触 MySQ ... web开发中经常涉及前端网页——php——mysql之间的数据交互,当数据只有英文时通常不会有什么问题,但一旦涉及中文,三个地方的某一处字符编码不一致(如,网页使用的时gbk而mysql使用utf-8 ... 原文:http://blog.csdn.net/woslx/article/details/49685111 utf-8编码可能2个字节.3个字节.4个字节的字符,但是MySQL的utf8编码只支持3 ... 一.mysql的安装.这个相对简单,直接去官网下载mysql安装程序.就能够完毕安装过程,网上有非常多安装教程,这个没什么注意事项. 二.C++訪问mysql.主要是用到mysql定义的头文件,内部定 ... show variables like %char% character_set_client | gb2312 character_s ... Interleaving String Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2. Fo ... 摘要 记录遇到的一些问题和解决方案 时差 数据容量 多表联动 1. 时差 问题描述 highcharts 默认是标准 UTC 时间,而国内默认是东八区时间,所以会有8个小时的时差 解决方法 使用hig ... 1.编号列表: <ol type="A" start="1"> //type中有"A","1",&qu ... 做Java开发已经一年,并非科班出身,在毕业工作三年后毅然决然辞职,参加培训机构从零开始.在这期间迷茫.失望.绝望时常伴我左右,但是在不断自我提高与努力中渐渐看到一些小小的成果使我不断坚信自己的选择并 ... 合抱之木,生于毫末,千里之行,始于足下,要想了解spring的文件上传功能,首先要知道spring是通过流的方式将文件进行解析,然后上传.那么是不是所有需要用的文件上传的地方都要写一遍文件解析器呢? ... 前面的话 本文将详细介绍域名解析模块DNS 工作原理 打开浏览器,在上方地址栏输入网址的那一刻,这个回车按了之后,发生了很多事情.首先,计算机只懂0和1,也就是说人类的字母网址计算机是不懂的,它只认识 ... 前置教程: 1. 实例甜点前面的三篇教程: 2. 最好看看笔者前面的一篇关于博文(后记:本来笔者想用C++做DragAndDrop的功能,但是失败了,下面是蓝图实现的方法): http://www.c ... 前言 这篇博文接 [前端]react and redux教程学习实践,浅显易懂的实践学习方法. ,上一篇简略的做了一个redux的初级demo,今天深入的学习了一些新的.有用的,可以在生产项目中使用的 ... 写在开始 一开始将自己hexo部署到github,结果发现打开页面速度有点慢,然后又将其同时部署到coding,实现双线路访问,国内解析记录到coding,国外解析到github,这样确实网站的速度能 ... 本文目录: 1.1 PXE说明 1.2 PXE流程 1.3 部署环境说明 1.4 部署DHCP 1.5 部署TFTP 1.6 提供pxe的bootloader和相关配置文件 1.7 利用原版安装镜像获 ...
如执行INSERT INTO member(memberName)VALUES('
拨开字符编码的迷雾--MySQL数据库字符编码的更多相关文章
随机推荐