Mysql字符集(3)--mysql从入门到精通(四)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql字符集(3)--mysql从入门到精通(四)

上篇文章我们说了mysql客户端到服务端会不同的字符集不断转换,其中服务端有三个重点的系统变量,1.处理客户端发来的字节串:character_set_client。2.吧请求的字节串从character_Set_cliect转成character_set_connection。3.吧字节串返回给客户端:character_Set_result。

Mysql字符集(2)--mysql从入门到精通(三)



如果你的select * from table_A where name = ‘我的’;返回的结果显示编码报错怎么办呢?


把我们可以从字节集的流程开始分析,他可能在第一步character_Set_client转换的时候就出现乱码问题,比如我们客户端发送的字节串是utf8的,但服务器的character_Set_client不是,就会乱码。也有可能character_Set_result字符集和客户端读取的字符集不一致也会乱码。这时候可以用:

Show variables like ‘character_Set_resultes’;


查看是否是和客户端相同的字符集,需要注意的是,mac的客端默认字符集是utf8,windows默认gbk。


字节串在服务器里面相互解码编码不是很影响性能吗,答案是肯定的,所以mysql给了一个sql,吧这三个系统参数一起修改字符集:set names '字符集';也可以单个修改,sql如下。

mysql> set names 'utf8';
Query OK, 0 rows affected (0.00 sec)
mysql> set character_Set_Results = 'utf8';
Query OK, 0 rows affected (0.00 sec)

主要流程就是:


1、mac客户端发送uft8字符集的字节串给服务器,服务器用character_Set_client解析。(如果采用的是navicat等客户端,客户端可能会自定义其字节的字符集进行发送)

2、如果character_set_connection字符集和 character_Set_client不同,则‘我的’字节串 ,会先由utf8找到其对应的字符串’我的‘进行解码,解码之后,再有character_Set_connection的字符集gbk或者什么字符集进行编码处理。

3、这时候看看查询的列字符集是否与character_Set_connection是否一致,如果不一致,还需要和上面那样进行转换。

4、吧character_Set_connection返回的字节串先解码成字符串,然后在用character_Set_results编码成utf8新的字节串返回给客户端

5、由于客户端使用的字符集和character_Set_results是相同的字符集,所以我们能正常查看。


比较规则的应用:


gbk_chinese_ci是不区分大小写排序的,比如order by 排序字段,返回的结果可能是’a’,’A’,’b’,’B’。

当我们用修改当前字段列的字符集为gbk_bin,order by排序之后,可以返回’A’,’B’,’a’,’b’。所以当我们排序时候,没有我们想要的结果,也可以考虑是否是比较规则的问题。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
2月前
|
关系型数据库 MySQL 数据库
MySQL基本操作入门指南
MySQL基本操作入门指南
79 0
|
2月前
|
SQL 关系型数据库 MySQL
MySQL入门到精通
MySQL入门到精通
|
4月前
|
存储 人工智能 关系型数据库
MySQL 8.0 字符集与比较规则介绍
我们都知道 MySQL 8.0 与 MySQL 5.7 的区别之一就是默认字符集从 latin1 改成了 utf8mb4 ,除此之外,MySQL 8.0 下的字符集和比较规则还有没有其他变化呢?本篇文章我们一起来学习下。
248 1
|
4月前
|
SQL 关系型数据库 MySQL
「Python入门」python操作MySQL和SqlServer
**摘要:** 了解如何使用Python的pymysql模块与MySQL数据库交互。首先,通过`pip install pymysql`安装模块。pymysql提供与MySQL的连接功能,例如创建数据库连接、执行SQL查询。在设置好MySQL环境后,使用`pymysql.connect()`建立连接,并通过游标执行SQL(如用户登录验证)。注意防止SQL注入,使用参数化查询。增删改操作需调用`conn.commit()`来保存更改。pymssql模块类似,但导入和连接对象创建略有不同。
60 0
「Python入门」python操作MySQL和SqlServer
|
4月前
|
SQL 关系型数据库 MySQL
【MySQL从入门到精通】常用SQL语句分享
【MySQL从入门到精通】常用SQL语句分享
57 2
|
5月前
|
关系型数据库 MySQL 数据库
『Django』模型入门教程-操作MySQL
一个后台如果没有数据库可以说废了一半。日常开发中大多数时候都在与数据库打交道。Django 为我们提供了一种更简单的操作数据库的方式。 在 Django 中,模型(Model)是用来定义数据库结构的类。每个模型类通常对应数据库中的一个表,类的属性对应表中的列。通过定义模型,Django 的 ORM(Object-Relational Mapping)可以将 Python 对象映射到数据库表,并提供一套 API 来进行数据库操作。 本文介绍模型的用法。
|
5月前
|
Java 关系型数据库 MySQL
Mybatis入门之在基于Springboot的框架下拿到MySQL中数据
Mybatis入门之在基于Springboot的框架下拿到MySQL中数据
48 4
|
5月前
|
存储 自然语言处理 关系型数据库
|
4月前
|
存储 关系型数据库 MySQL
MySQL小白教程:从入门到查询高手
MySQL小白教程:从入门到查询高手