MySQL 字符集 编码 校队

数据库表被用来存储和检索数据。不同的语言和字符集需要以不同的方式存储和检索。因此,MySQL需要适应不同的字符集(不同的字母和字符),适应不同的排序和检索数据的方法。

❑ 字符集 为字母和符号的集合;

❑ 编码 为某个字符集成员的内部表示;

❑ 校对 为规定字符如何比较的指令。

 

查看编码和校对

复制代码
-- 查看所支持的字符集完整列表
show CHARACTER SET;
show CHARACTER SET where SUBSTR(CHARSET,1,3) = 'utf';
-- 查看所支持校对的完整列表
show COLLATION;
show COLLATION where SUBSTR(COLLATION,1,4) = 'utf8';
-- 查看所用的字符集和校对
show VARIABLES like 'CHARACTER%';
show VARIABLES like 'COLLATION%';
复制代码

例如,latin1对不同的欧洲语言有几种校对,而且许多校对出现两次,一次区分大小写(由_cs表示),一次不区分大小写(由_ci表示)。

 

设置字符集和校对顺序

为了给表指定字符集和校对,可使用带子句的CREATE TABLE

MySQL还允许对每个列设置它们

DROP TABLE  IF EXISTS table_a2;
CREATE TABLE `table_a2` (
  `aid` int(11) NOT NULL,
  `name` varchar(255) CHARSET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL,
  PRIMARY KEY (`aid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

 

使用校对顺序

SELECT * FROM `table_a2`
ORDER BY name COLLATE utf8mb4_general_ci

除了这里看到的在ORDER BY子句中使用以外,COLLATE还可以用于GROUP BY、HAVING、聚集函数、别名等。

 

posted @   草木物语  阅读(125)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示