Mysql中的collation (stage1-9)

MySQL字符排序详解
本文详细介绍了MySQL中的字符排序(collation)概念及其应用场景。字符排序决定了如何比较字符数据,包括大小写敏感性和特殊字符处理等。文章通过示例对比了不同字符排序设置下SQL查询结果的差异。

mysql的collation大致的意思就是字符排序。
首先字符本来是不分大小的,那么对字符的>, = , < 操作就需要有个字符序的规则。collation做的就是这个事情,你可以对表进行字符序的设置,也可以单独对某个字段进行字符序的设置。一个字符类型,它的字符序有多个,比如:

下面是UTF8对应的字符序。

utf8_general_ci utf8    33  Yes Yes 1
utf8_bin    utf8    83      Yes 1
utf8_unicode_ci utf8    192     Yes 8
utf8_icelandic_ci   utf8    193     Yes 8
utf8_latvian_ci utf8    194     Yes 8
utf8_romanian_ci    utf8    195     Yes 8
utf8_slovenian_ci   utf8    196     Yes 8
utf8_polish_ci  utf8    197     Yes 8
utf8_estonian_ci    utf8    198     Yes 8
utf8_spanish_ci utf8    199     Yes 8
utf8_swedish_ci utf8    200     Yes 8
utf8_turkish_ci utf8    201     Yes 8
utf8_czech_ci   utf8    202     Yes 8
utf8_danish_ci  utf8    203     Yes 8
utf8_lithuanian_ci  utf8    204     Yes 8
utf8_slovak_ci  utf8    205     Yes 8
utf8_spanish2_ci    utf8    206     Yes 8
utf8_roman_ci   utf8    207     Yes 8
utf8_persian_ci utf8    208     Yes 8
utf8_esperanto_ci   utf8    209     Yes 8
utf8_hungarian_ci   utf8    210     Yes 8
utf8_sinhala_ci utf8    211     Yes 8
utf8_german2_ci utf8    212     Yes 8
utf8_croatian_ci    utf8    213     Yes 8
utf8_unicode_520_ci utf8    214     Yes 8
utf8_vietnamese_ci  utf8    215     Yes 8
utf8_general_mysql500_ci    utf8    223     Yes 1

mysql的字符序遵从命名惯例
以_ci(表示大小写不敏感)
以_cs(表示大小写敏感)
以_bin(表示用编码值进行比较)

比如:

CREATE TABLE `issue_message` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `content` varchar(255) NOT NULL,
  PRIMARY KEY (`id`),
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

这个表下面的两个sql会出现同样的结果

select * from issue_message where content = 'Yes'
select * from issue_message where content = 'yes'

如果改成下面的定义:

CREATE TABLE `issue_message` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `content` varchar(255) NOT NULL COLLATE utf8_bin,
  PRIMARY KEY (`id`),
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

那么两个sql结果就会不一样了。

所以,如果对字符大小写敏感的话,最好将数据库中默认的utf8_general_ci设置为utf8_bin。

### 解决 Docker 启动 MySQL 权限错误 当 Docker 启动 MySQL 出现 `Error response from daemon: failed to create shim task: OCI runtime create failed: container_linux.go:318: starting container process caused "permission denied": unknown` 错误,可从以下方面排查解决: - **检查文件和目录权限**:若挂载了主机的文件或目录到容器中,需要确保这些文件和目录的权限是正确的。可以使用 `chmod` 和 `chown` 命令来修改权限和所有者。 ```bash # 修改目录权限为 755 chmod 755 /path/to/your/mysql/data # 修改目录所有者为当前用户 chown -R your_user:your_group /path/to/your/mysql/data ``` - **检查 SELinux 或 AppArmor**:SELinux 或 AppArmor 等安全模块可能会限制 Docker 容器的访问权限。可以临时禁用 SELinux 或 AppArmor 来检查是否是这些安全模块导致的问题。 ```bash # 临时禁用 SELinux setenforce 0 # 临时禁用 AppArmor sudo systemctl stop apparmor sudo systemctl disable apparmor ``` 也可在启动容器时使用 `--security-opt apparmor=unconfined` 参数。 - **检查 Docker 服务权限**:确保 Docker 服务有足够的权限来创建和启动容器,可尝试重启 Docker 服务。 ```bash sudo systemctl restart docker ``` - **检查用户组**:确保当前用户属于 `docker` 用户组。 ```bash # 将用户添加到 docker 用户组 sudo usermod -aG docker your_user # 重新登录使更改生效 su - your_user ``` - **检查镜像和容器**:有时候,镜像本身可能存在问题。可以尝试删除并重新拉取 MySQL 镜像,然后重新创建容器。 ```bash # 删除 MySQL 镜像 docker rmi mysql:8.0.35 # 重新拉取 MySQL 镜像 docker pull mysql:8.0.35 # 重新创建并启动容器 docker-compose -f docker-compose.yml up -d ``` ### 检查 `docker-compose.yml` 配置 提供的 `docker-compose.yml` 配置整体上没有明显语法错误,但有一些小问题需要注意: - `restart: unless - stopped` 存在拼写错误,正确的应该是 `restart: unless-stopped`。 - `command` 部分的参数存在空格问题,正确的参数名应该是 `--default-authentication-plugin`、`--character-set-server`、`--collation-server`。 以下是修正后的 `docker-compose.yml` 文件: ```yaml version: &#39;3.8&#39; services: mysql: image: mysql:8.0.35 container_name: mysql8 restart: unless-stopped environment: MYSQL_ROOT_PASSWORD: admin MYSQL_DATABASE: fireall TZ: Asia/Shanghai ports: - "3306:3306" volumes: - mysql_data:/var/lib/mysql command: - --default-authentication-plugin=mysql_native_password - --character-set-server=utf8mb4 - --collation-server=utf8mb4_unicode_ci - --lower_case_table_names=1 volumes: mysql_data: ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值