首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

utf8字符集下的比较规则

前言: 在MySQL中,比较常用的字符集utf8和utf8mb4。...这两个字符集是类似的,utf8是utf8mb3的别名,所以之后在MySQL中提到utf8就意味着使用1~3个字节来表示一个字符,如果大家有使用4字节编码一个字符的情况,比如存储一些emoji表情啥的,需要使用...1.utf8下比较规则概览 我们先查看下utf8字符集下支持的所有比较规则: mysql> SHOW COLLATION LIKE 'utf8\_%'; +----------------------...每种字符集都有一种默认的比较规则,SHOW COLLATION的返回结果中的Default列的值为YES的就是该字符集的默认比较规则,比方说utf8字符集默认的比较规则就是utf8_general_ci...表名 MODIFY 列名 字符串类型 [CHARACTER SET 字符集名称] [COLLATE 比较规则名称]; 2.几种比较规则对比 utf8字符集下默认的比较规则是utf8_general_ci

1.3K21

MySQL字符集你还在使用错误的utf8

所有在使用“utf8”的MySQL和MariaDB用户都应该改用“utf8mb4”,永远都不要再使用“utf8”。 MySQL的“utf8”不是真正的UTF-8。...“utf8”只支持每个字符最多三个字节,而真正的UTF-8是每个字符最多四个字节。 MySQL一直没有修复这个bug,他们在2010年发布了一个叫作“utf8mb4”的字符集,绕过这个问题。 ?...几乎所有的网络应用都使用了Unicode字符集。Unicode字符集包含了上百万个字符。最简单的编码是UTF-32,每个字符使用32位。...但是MySQL的“utf8字符集与其他程序还不兼容! MySQL从4.1版本开始支持UTF-8,也就是2003年,而今天使用的UTF-8标准(RFC 3629)是随后才出现的。...同年9月,他们对MySQL源代码进行了一次调整:“UTF8现在最多只支持3个字节的序列”。 utfmb4字符集 支持BMP和补充字符。 每个多字节字符最多需要四个字节。

1.2K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL字符集utf8和utf-8的关系

    是MySQL存储Unicode数据的一种可选方法 utf8 MySQL中实现了UTF-8编码的unicode 字符集 MySQL中utf8是utf8mb3的别名 utf8中,一个符号使用1~3个节点表示...对UTF-8支持不彻底,可采用utf8mb4字符集 utf8与utf8mb4的关系 都是实现了UTF-8编码的unicode 字符集 utf8仅支持基本多语言平面Basic Multilingual...个字节存储 对于BMP字符,utf8和utf8mb4具有相同的编码,相同的长度 对于非BMP字符,utf8mb4使用4个字节来存储,utf8不能存储非BMP字符 innodb中默认最大可对767个字节建立索引...使用utf8 的列最多可对255个字符建立索引 使用utf8mb4 的列最多可对191个字符建立索引 超集 字符集A,B ,B支持的所有字符A都支持,A 是B超集 比如 GBK字符集是GB2312字符集的超集...,它们又都是ASCII字符集的超集 utf8mb4是utf8的超集 字符集设置 set names x 等价于 set character_set_client=x; set character_set_connection

    79510

    Linux下MySQL的彻底卸载和安装配置字符集

    前言: Linux环境下MySQL的安装和配置在网上已经有很多教程了。之所以写这篇文章是因为在配置字符集的时候找了网上的一些教程发现并不能用导致折腾了一阵子。下面的教程均是亲自实践。...MySQL的彻底卸载 首先查看一下自己是否已经安装了MySQL。代码如下: 1 ps -aux|grep mysql 如未安装则不显示任何内容,若安装则会显示如下的信息: ?...MySQL字符集的配置 首先我们在终端打开mysql: 1 mysql -uroot -p 然后输入密码即可进入mysql 然后我们输入下面的查询语句来查看默认的字符集设置: 1 show variables...以上版本修改如下: 【client】 default-character-set = utf8 【mysqld】 character-set-server = utf8 ?...接下来进入mysql,再来看一下字符集设置: ? 可以看到除了system之外均该为了utf8. 注意 改字符集之前建立的数据库内的数据仍是中文乱码,这时我们备份一下数据新建即可。

    1.7K70

    MySql高级----Linux下的mysql的安装与初始化配置

    MySql高级部分 Linux安装mysql的步骤 首先查看当前linux系统是否安装过mysql的rpm包 去mysql官网下载对应版本的rpm包 将下载的mysql文件,上传到linux的/opt...mysql的安装位置 修改默认配置文件 拷贝默认配置文件到/etc/my.cnf 重启mysql服务 修改字符集----中文乱码 查看字符集 修改默认字符集---修改配置文件 修改完默认字符集后...,所以会乱码 ---- 修改默认字符集—修改配置文件 来到/etc目录下面,编辑my.cnf配置文件 ---- 首先将客户端的字符集设置为utf8 default-character-set=utf8...---- 修改服务端的字符集 character_set_server=utf8 character_set_client=utf8 collation-server=utf8_general_ci...---- 在mysql下面再设置一个默认字符集: default-character-set=utf8 ---- 修改完默认字符集后,重启mysql,重启成功说明配置文件修改的没问题 ---- 打开

    2.2K20

    linux 下mysql的安装,并设置必要的密码

    --with-extra-charsets:服务器需要支持的字符集,有三种可能的值:空格间隔的一系列字符集名;complex ,包括不能动态装载的所有字符集;all,将所有字符集包括进二进制。...注意:要想更改字符集和校对规则,要同时使用--with-charset和--with-collation选项。 校对规则必须是字符集的合法校对规则。...打开my.cnf修改编码   在[client]下增加default-character-set=utf8   在[mysqld]下增加default-character-set=utf8   同时加上...init_connect='SET NAMES utf8' (设定连接mysql数据库时使用utf8编码,以让mysql数据库为utf8运行)  www.2cto.com   ?...解决的办法是:创建数据库的时候指明默认字符集utf8,如:   create database test default character set utf8;

    2.9K100

    技术分享 | 为什么我的 MySQL 客户端字符集为 latin1

    问题背景 我司某客户最近在检查一批新安装的 MySQL 数据库时,发现了下面的现象: 该批次的 MySQL 客户端字符集全部为 Latin1 ; 而之前使用同样参数模板部署的 MySQL ,客户端字符集却为...utf8 ; 已知 MySQL 版本为 5.7.32 ,服务器操作系统为 Redhat 7 ,那么为什么两次安装的 MySQL 字符集会不一样呢?...MySQL 的字符集,确实为 utf8 [qinguangfei0511-2.png] 之后,查看服务器上所有的 my.cnf 文件,发现无论是之前安装的还是最近一批安装的,都仅有 MySQL 运行时指定的...,MySQL 5.7 是 latin1 ,MySQL 8.0为 utf8mb4 ; 每个客户端工具都会检测操作系统的字符集,比如Linux系统LANG环境变量的值,如果MySQL支持操作系统的字符集,就会使用操作系统的...参数指定; 控制 MySQL Client 级别字符集的三个参数需要保持一致,一般来说为utf8(MySQL 8.0 为 utf8mb4),同时又与 MySQL Client 所在服务器的字符集有关;

    1.9K30
    领券