MySQL 字符集与比较规则

由于 MySQL 客户端与服务端之间通信时需要将字符串编码传输,所以不可避免会产生编码转换

字符集

MySQL 中 utf8 就是 utf8mb3,只使用 1~3 个字节表示字符

utf-8md4 使用 1~4 个字节表示字符

相关参数

MySQL 服务器有以下几个参数与编码有关

字符集相关参数:

character_set_server 服务器级别的字符集

character_set_database 当前数据库的字符集 (如果没有使用 USE 选择数据库,则查看服务器级别的字符集) 只读,无法通过修改改变当前数据库参数

字符集转换相关参数:

character_set_client 服务器会认为客户端发送的请求为这个字符集,会将请求以这个字符集的形式进行解码,获取请求内容

character_set_connection 服务器内部处理请求时使用的字符集,服务器会将客户端的请求以这个字符集的形式进行编码 (如果与处理的数据字符集不同就会再进行一次转换)

character_set_results 服务器会将返回的结果以这个字符集的形式进行编码后返回给客户端

查看命令

MySQL 支持许多字符集,通过以下命令可以查看所有支持的字符集

SHOW CHARACTER SET;
SHOW CHARSET;

其中 Default collation 就是这种字符集的默认比较规则,Maxlen 就是这种字符集表示一个字符最多需要的字节数

查看其他参数

SHOW VARIABLES LIKE 'character_set_server';
SHOW VARIABLES LIKE 'character_set_database';
SHOW VARIABLES LIKE 'character_set_client';
SHOW VARIABLES LIKE 'character_set_connection';
SHOW VARIABLES LIKE 'character_set_results';

设置命令

设置字符集参数

服务器级别:

SET character_set_server 字符集名;

数据库级别:

CREATE DATABASE 数据库名
CHARACTER SET 字符集名称; ALTER DATABASE 数据库名
CHARACTER SET 字符集名称;

表级别

CREATE TABLE 表名 (列的信息)
CHARACTER SET 字符集名称; ALTER TABLE 表名
CHARACTER SET 字符集名称;

列级别

CREATE TABLE 表名(列名 字符串类型 CHARACTER SET 字符集名称);

ALTER TABLE 表名 MODIFY 列名 字符串类型 CHARACTER SET 字符集名称 ;

设置字符集转换参数

一般为了方便会将三个参数设置为同一字符集

使用以下命令就可以同时设置三个参数

SET NAMES 字符集名;

当然也可以分开设置

SET character_set_client = 字符集名;
SET character_set_connection = 字符集名;
SET character_set_results = 字符集名;

比较规则

比较规则有时也称为排序规则,用于在字符串比较大小时规定其顺序的

同一种字符集可以有多种比较规则

命名规则

每一种字符集都可能对应多种比较规则,这些比较规则命名规律为

  • 比较规则名称以对应的字符集名称开头
  • 中间部分表示主要用于哪种语言
  • 后缀有以下几种:
后缀 全称 含义
`_ai` accent insensitive 不区分重音
`_as` accent sensitive 区分重音
`_ci` case insensitive 不区分大小写
`_cs` case sensitive 区分大小写
`_bin` binary 以二进制方式比较

示例:
`utf8_spanish_ci` 表示以西班牙语比较,且不区分大小写

相关参数

collation_server 服务器级别的比较规则

collation_database 当前数据库的比较规则 (如果没有使用 USE 选择数据库,则查看服务器级别的比较规则) 只读,无法通过修改改变当前数据库参数

查看命令

将比较规则全部列出来比较多,可以根据对应的字符集进行筛选

SHOW COLLATION;
SHOW COLLATION LIKE 'utf8\_%';

其中 Charset 表示对应的字符集,Default 表示是否为默认比较规则

设置命令

设置比较规则参数

服务器级别:

SET collation_server 比较规则名;

数据库级别:

CREATE DATABASE 数据库名
COLLATE 比较规则名称; ALTER DATABASE 数据库名
COLLATE 比较规则名称;

表级别

CREATE TABLE 表名 (列的信息)
COLLATE 比较规则名称; ALTER TABLE 表名
COLLATE 比较规则名称;

列级别

CREATE TABLE 表名(列名 字符串类型 COLLATE 比较规则名称);

ALTER TABLE 表名 MODIFY 列名 字符串类型 COLLATE 比较规则名称 ;

总结

当只修改某个级别的字符集或比较规则时,相同级别对应的比较规则或字符集也会跟着改变为对应的 (默认的)

当创建数据库时如果没有指定字符集和比较规则,则默认使用服务器级别的参数

创建表时没有指定字符集和比较规则,则默认使用表所在数据库的参数

创建列时没有指定字符集和比较规则,则默认使用列所在表的参数

MySQL 字符集与比较规则的更多相关文章

  1. MySQL字符集与排序规则总结

      字符集与排序规则概念 在数据库当中都有字符集和排序规则的概念, 很多开发人员甚至包括有些DBA都会将这个混淆,当然这个情况也有一些情有可原的原因.一来两者本来就是相辅相成,相互依赖关联: 另外一方 ...

  2. MySql字符集与排序规则详解

    前段时间往MySQL中存入emoji表情或生僻字.繁体字时,报错无法添加,研究后发现这是字符集编码的问题,今天就来分析一下各个字符集与排序规则 一.字符集 先说字符,字符是各种文字和符号的总称,包括各 ...

  3. MySQL字符集及校对规则的理解

      阅读目录:MySQL的字符集和校对规则 MySQL的字符集 MySQL与字符集 正确使用字符集 MySQL客户端与字符集 字符集编码转换原理 字符集常见处理操作 字符集的正确实践 MySQL的校对 ...

  4. Mysql字符集与校对规则

    字符集是一套字符和编码的集合,校对规则是用于比较字符集的一套规则. 所以字符集有两部分组成字符集合和对应的编码集合.比如说,现在有这几个字符:A B a b, 假设它们对应的编码分别是00, 01, ...

  5. mysql字符集与比较规则

    MySQL有4个级别的字符集和比较规则,分别是: 服务器级别 数据库级别 表级别 列级别 查看服务器级别命令: mysql> SHOW VARIABLES LIKE 'character_set ...

  6. MySQL 字符集及校验规则

    字符集 Mysql 的字符集有4个级别的默认设置:服务器级,数据库级,表级和字段级,客户端交互时,也可以指定字符集 # 字符集:是一个系统支持的所有抽象字符的集合.字符是各种文字和符号的总称,包括各国 ...

  7. Mysql 字符集及排序规则

    一.字符集 字符集:就是用来定义字符在数据库中的编码的集合. 常见的字符集:utf8.Unicode.GBK.GB2312(支持中文).ASCCI(不支持中文)   二.字符集排序规则   作者本人用 ...

  8. mysql字符集问题,及排序规则

    字符集问题: 基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如’A'.’B'等:• 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(E ...

  9. MySQL 字符集和校验规则工作流程

    MySQL 字符集和校验规则工作原理 字符编码相关参数 数据流中的转码过程 校验规则 Tips:字符集和校验规则总是相伴的 一 从简单的建库语句开始 CREATE DATABASE [IF NOT E ...

随机推荐

  1. Java之封装性

    封装概述 面向对象编程语言是对客观世界的模拟,客观世界里成员变量都是隐藏在对象内部的,外界无法直接操作和修改. 封装可以被认为是一个保护屏障,防止该类的代码和数据被其他类随意访问.要访问该类的数据,必 ...

  2. 趣谈Linux操作系统学习笔记:第二十五讲

    一.mmap原理 在虚拟内存空间那一节,我们知道,每一个进程都有一个列表vm_area_struct,指向虚拟地址空间的不同内存块,这个变量名字叫mmap struct mm_struct { str ...

  3. Matplotlib绘图及动画总结

    目录 Matplotlib绘图总结 绘图原理 block模式(python默认) interactive模式(ipython模式默认) 深入子图 子图表示 子图绘图 绘制动画 参考链接 Matplot ...

  4. IT兄弟连 HTML5教程 介绍HTML5给你认识 习题

    1.关于HTML5说法正确的是:(C) A.HTML5只是对HTML4的一个简单升级 B.所有主流浏览器都支持HTML5 C.HTML5新增了离线缓存机制 D.HTML5主要是针对移动端进行了优化 2 ...

  5. IT兄弟连 HTML5教程 了解HTML5的主流应用1

    在很多人眼里,HTML5与互联网营销密切相关,但其实从开发者的角度而言,它是一种网页标准,定义了浏览器语言的编写规范.伴随HTML5标准尘埃落定,浏览器对HTML5特性的逐步支持,再加上国内对HTML ...

  6. 使用pymysql模块进行封装,自动化不可或缺的数据库校验

    import pymysql class HandleMysql: ''' 定义一个mysql处理类 ''' def __init__(self, hostname, username, passwo ...

  7. VSCode 开发插件 推荐

    VSCode 必装的 10 个高效开发插件  本文介绍了目前前端开发最受欢迎的开发工具 VSCode 必装的 10 个开发插件,用于大大提高软件开发的效率. VSCode 的基本使用可以参考我的原创视 ...

  8. 【数字图像分析】基于Python实现 Canny Edge Detection(Canny 边缘检测算法)

    Canny 边缘检测算法 Steps: 高斯滤波平滑 计算梯度大小和方向 非极大值抑制 双阈值检测和连接 代码结构: Canny Edge Detection | Gaussian_Smoothing ...

  9. oracle学习笔记(十三) 查询练习(三) 子查询查询

    子查询练习 create table empployee_demo( empno number(4) not null primary key, --员工编号,主键 ename varchar2(10 ...

  10. C#测试对比不同类型的方法调用的性能

    一. 测试方法调用形式 1. 实例方法调用 2. 静态方法调用 3. 实例方法反射调用 4. 委托方法的Invoke调用 5. 委托方法的DynamicInvoke调用 6.委托方法的BeginInv ...