【MySQL】调控 字符集
创始人
2024-05-26 23:22:36
0

一、 MySQL 启动选项 & 系统变量

启动选项 是在程序启动时我们程序员传递的一些参数,而 系统变量 是影响服务器程序运行行为的变量

1.1 启动项

MySQL 客户端设置项包括: 允许连入的客户端数量 、 客户端与服务器的通信方式 、 表的默认存储引擎 、 查循缓存 的大小等,这些设置项往往具有一定的默认值,这些设置项被称为 启动项

- 命令行使用启动项 (只对当次生效)

以修改服务器默认存储引擎为例子,我们通过以下命令启动 MySQL 服务器,从而修改存储引擎

mysqld --default-storage-engine=MyISAM

启动服务器程序的命令行指定启动选项的通用格式:

--启动选项1[=值1] --启动选项2[=值2] ... --启动选项n[=值n]

可以通过 --help 查看所有的启动选项及其默认值:

mysqld 查看帮助选项如下:

 mysqld --verbose --help

- 配置文件使用启动项

- - 配置文件地址

Windows 系统

在这里插入图片描述

类 Unix 系统

在这里插入图片描述

- - 配置文件内容

[组名] (具体启动选项)

注意:

  1. 每行指定一个选项
  2. 等号周围可有空格字符
  3. 可以使用 # 表注释
  4. 各个启动命令读取的组

在这里插入图片描述

  1. 配置文件具有优先级,多个配置文件,以最后一个配置文件为准
  2. 组具有优先级,以最后一个出现的组为准
  3. 可以指定配置文件 mysqld --defaults-file=

1.2 系统变量

查看系统变量的方式:

SHOW VARIABLES [LIKE 匹配的模式];

- 通过启动变量设置

- 在服务器运行过程中设置

- 作用范围

  • GLOBAL :全局变量,影响服务器的整体操作。
  • SESSION :会话变量,影响某个客户端连接的操作。(注: SESSION 有个别名叫 LOCAL )
SET [GLOBAL|SESSION] 系统变量名 = 值;

注意:

  1. 并不是所有系统变量都有这两种作用范围,一些只有 GLOBAL ,一些只有 SESSION
  2. 有些系统变量是只读的
  3. 省略作用范围,作用范围为 SESSION



二、字符集

- 什么是字符集

界定字符的范围,然后建立字符与二进制数据的映射关系

- 字符集比较规则

将大小不同的字符转为全大写或者全小写,然后转化为二进制编码进行比较

- 重要字符集

- - ASSIC

共 128 字符,包括大小写字母,标点、数字、空格和一些不可见字符 。

- - ISO 8859-1 (latin1)

在 ASCII 字符集的基础上又扩充了 128 个西欧常用字符 (包括德法两国的字母) 。

- - GB2312

收录了汉字以及拉丁字母、希腊字母、日文平假名及片假名字母、俄语西里尔字母。其中收录汉字6763个,其他文字符号 682 个。同时这种字符集又兼容 ASCII 字符集 。

- - GBK

GBK 字符集只是在收录字符范围上对 GB2312 字符集作了扩充,编码方式上兼容 GB2312 。

- - utf8

收录地球上能想到的所有字符,而且还在不断扩充,这种字符集兼容 ASCII 字符集,采用变长编码方式,编码一个字符需要使用1~4个字节 。

- MySQL 支持的字符集

SHOW CHARSET;

- - utf8 && utf8mb4

utf8mb3 :阉割过的 utf8 字符集,只使用1~3个字节表示字符。
utf8mb4 :正宗的 utf8 字符集,使用1~4个字节表示字符。—— 存储 emoji 表情

- - MySQL 字符集比较规则

对字符串做比较或者对某个字符串列做排序操作时没有得到想象中的结果,需要思考一下是不是 比较规则的问题

SHOW COLLATION [LIKE 匹配的模式];
  • 如果创建或修改列时没有显式的指定字符集和比较规则,则该列默认用表的字符集和比较规则
  • 如果创建或修改表时没有显式的指定字符集和比较规则,则该表默认用数据库的字符集和比较规则
  • 如果创建或修改数据库时没有显式的指定字符集和比较规则,则该数据库默认用服务器的字符集和比较规则

- - 乱码的产生

编码和解码使用的字符集不相同

- - 字符集的转换

类 Unix 系统使用的是 utf8
Windows 使用的是 gbk

注意:

  1. 服务器认为客户端发送过来的请求是用 character_set_client 编码的
  2. 假设你的客户端采用的字符集和 character_set_results 不一样的话,这就可能会出现客户端无法解码结果集的情况

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...