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

mysql创建数据库排序规则

MySQL创建数据库时可以指定排序规则,排序规则决定了在进行字符串比较和排序时的行为。MySQL支持多种排序规则,包括不区分大小写的排序规则和区分大小写的排序规则。

  1. 不区分大小写的排序规则(case-insensitive):
    • 概念:不区分字符串的大小写,在比较和排序时忽略大小写的差异。
    • 分类:默认排序规则为utf8_general_ci,ci表示case insensitive。
    • 优势:适用于需要不区分大小写的场景,提高了灵活性和兼容性。
    • 应用场景:例如在用户表的用户名字段上使用不区分大小写的排序规则,可以避免重复的用户名。
  • 区分大小写的排序规则(case-sensitive):
    • 概念:区分字符串的大小写,在比较和排序时考虑大小写的差异。
    • 分类:默认排序规则为utf8_general_cs,cs表示case sensitive。
    • 优势:适用于需要区分大小写的场景,保留了大小写的差异。
    • 应用场景:例如在代码表的枚举值字段上使用区分大小写的排序规则,确保准确匹配枚举值。

在MySQL中创建数据库时,可以通过指定排序规则来设定数据库的默认排序规则。例如,使用以下语句创建一个名为"mydb"的数据库,并指定排序规则为不区分大小写的utf8_general_ci:

代码语言:txt
复制
CREATE DATABASE mydb DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

对于现有的数据库,也可以使用ALTER DATABASE语句来修改排序规则。

腾讯云相关产品和产品介绍链接地址:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL创建数据库指定编码和排序规则mysql数据库密码重置

MySQL 数据库基本使用 mysql 数据库创建与密码重置 ① 数据库登录与密码设置 ② 数据库创建并指定编码和排序规则 ③ 切换数据库 ④ 删除数据库创建用户 ⑥ 给用户授权 mysql 数据库创建与密码重置...① 数据库登录与密码设置 root 用户登录:mysql -u root -p root 用户重置密码: alter user 'root'@'localhost' identified by 'xxx...'; 退出:exit; ② 数据库创建并指定编码和排序规则 创建数据库 sonic 并指定排序编码和排序规则: create database sonic default character...set utf8 collate utf8_general_ci; ③ 切换数据库 切换数据库 sonic:use sonic ④ 删除数据库 删除数据库 sonic:drop database...sonic ⑤ 创建用户 create user "用户名"@"localhost" identified by "密码" ⑥ 给用户授权 grant all privileges on 用户名.*

6.5K20

MySQL 排序规则

排序规则是一组用于比较字符集中的字符的规则。 每个 MySQL 字符集可以支持一个或者多个排序规则,用于定义每个字符的比较规则,包括是否区分大小写,是否区分重音等。...这是排序规则的唯一标识符,您可以在创建或更改表时使用它来指定表的排序规则。 Charset:字符集的名称。排序规则是与特定字符集关联的,该列显示了该排序规则适用的字符集。 Id:排序规则的内部编号。...这是MySQL内部使用的标识符。 Default:是否为默认排序规则。如果是默认排序规则,将显示“Yes”;否则,显示“”No”。 Compiled:是否已编译排序规则。...如果没有指定排序规则MySQL 会基于字符集设置一个默认的排序规则。...4.查看排序规则 查看数据库排序规则 您可以查询 information_schema 数据库的 SCHEMATA 视图来查看数据库排序规则

43720
  • MySQL字符集及其排序规则

    ---- 兼容性问题 ---- 由于utf8mb4_0900_ai_ci排序规则MySQL 8.0引入的排序规则,因此将MySQL 8.0版本的表导入到MySQL 5.7或MySQL 5.6版本时,会存在字符集无法识别的问题...[Err] 1273 - Unknown collation: 'utf8mb4_0900_ai_ci' 解决办法:修改新建数据库排序规则或手动修改 sql 文件内所有的排序规则。...它定义了在创建新表时使用的默认字符集校对规则 查看当前MySQL服务器的collation_server的值: SHOW VARIABLES LIKE 'collation_server'; 该命令将返回一个结果集...如果创建数据库时未指定排序规则,则默认使用参数collation_database的值。...在创建库或修改库指定utf8mb4但未指定编码规则时。 在创建表或修改表指定utf8mb4但未指定编码规则时。 在增加列或修改列指定utf8mb4但未指定编码规则时。

    1.7K20

    MySQL order by的不同排序规则

    explain语句执行的结果中,Extra项中含有Using filesort表示需要排序MySQL会给每个线程分配一块内存用于排序,称为sort_buffer。...对sort_buffer中的数据按order by条件快速排序。 按照排序结果取数据返回。 rowid排序 rowid排序涉及磁盘IO,需要一次回表操作,不受内存大小限制。...当排序的字段较多时,内存可放下的行数很少,需要分成很多个临时文件,排序性能很差,即MySQL认为排序的单行长度太大会使用rowid排序。...控制用于排序的行数据的长度,单行长度超过该值,MySQL更换排序算法 SET max_length_for_sort_data = 16; 使用索引排序 语句执行流程: 从索引找到第一个满足where...MySQL的一个设计思想:如果内存够,就要多利用内存,尽量减少磁盘访问。

    31140

    数据库PostrageSQL-排序规则支持

    排序规则支持 排序规则特性允许指定每一列甚至每一个操作的数据的排序顺序和字符分类行为。这放松了数据库的LC_COLLATE和LC_CTYPE设置自创建以后就不能更改这一限制。 23.2.1....附加的排序规则是否可用取决于操作系统的支持。default排序规则选择在数据库创建时指定的LC_COLLATE和LC_CTYPE值。...如果所需的libc 排序规则与LC_COLLATE和LC_CTYPE的值不同, 或者在数据库系统初始化之后, 操作系统中安装了新的语言环境,可以使用CREATE COLLATION 命令创建新的排序规则...在任何特定的数据库中,只有使用数据库编码的排序规则是令人感兴趣的。其他pg_collation中的项会被忽略。...由于预定义的libc排序规则已经包含了数据库实例初始化时在操作系统中定义的所有排序规则, 因此通常不需要手动创建排序规则

    1.5K20

    MySQL 的字符集与排序规则

    排序规则 创建库的时候,我们经常会使用语句: CREATE DATABASE dbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci; 既然我们知道了CHARSET...它代表着排序规则。...概念 MySQl排序规则(collation),一般指对字符集中字符串之间的比较、排序制定的规则, MySLQ排序规则特征: o 两个不同的字符集不能有相同的校对规则; o 每个字符集有一个默认校对规则...其实对于排序规则的细节问题,我们关注较少,反而对排序规则中是否涉及大小写敏感关注较多。 例如,系统使用 utf8 字符集,若使用 utf8_bin 排序规则,执行 SQL 查询时区分大小写。...例如,对于德语和法语,utf8_unicode_ci 工作的很好,因此不再需要为这两种语言创建特殊的 utf8 校对规则

    2.4K20

    技术分享 | MySQL--测试--排序规则 collation

    ---摘抄:https://dev.mysql.com/doc/refman/8.0/en/charset-general.htmlhttps://dev.mysql.com/doc/refman/8.0...字符集和排序规则的默认选择:如果你仅指定字符集,⽽不指定排序规则,则排序规则为字符集默认的排序规则;如果你仅指定排序规则,不指定字符集,则字符集为排序规则对应的字符集;例外项⻅: "设置对象的字符集和排序规则...COLLATION WHERE Charset = 'utf8mb4'; -- 这⾥的utf8mb4是具体的字符集查看数据库的默认字符集和排序规则:USE db_name;SELECT @@character_set_database...,则使⽤数据库中声明的作为默认值;如果load data时未带上character set⼦句,则使⽤character_set_database作为默认值;如果在创建routine时未带上字符集和排序规则...,则使⽤数据库中声明的作为默认值;table建表时的CHARACTER SET ⼦句;建表时的COLLATE ⼦句;如果未在单个列上指定字符集和排序规则,则将表中声明的作为默认值;column建表时字段定义上的

    1.2K30

    MySQL排序规则导致无法命中索引问题

    背景 因公司数据库设计不方便展示,语句使用以下数据表演示现象。...原因 在SQL的关联条件中,关联字段类型相同,并不是隐式类型转换问题导致无法命中索引,那么我们开始排查两表的字符集、排序规则是否一致。...user表设计: vehicle表设计: 两表字符集均为utf8mb4,不会出现因字符集不同导致隐式转换的问题,那么对比排序规则发现两表的排序规则是不同的,排序规则不一致时,MySQL同样会进行强制类型转换...解决方案 方案一:使用数据库管理工具或alter table语句修改排序规则。...方案二:将原表重命名备份, 修改原建表语句为正确的排序规则,执行建表语句,而后使用select into语句将旧表数据恢复到新表。

    31430

    MySQL原理 - 字符集与排序规则

    这些字符如何排序呢?决定字符排序规则就是排序规则。 查看内置字符集与比较规则 通过show charset;命令,可以查看所有的字符集。...= 'utf8mb4_general_ci'; Query OK, 0 rows affected (0.00 sec) 库级别 创建数据库的时候,可以指定字符集还有排序规则。...查看当前数据库的字符集还有排序规则则是通过use命令指定数据库之后,查看character_set_database变量以及collation_database来实现: mysql> show variables...表级别 可以在创建时指定字符集合排序规则,不指定的话,用数据库的字符集还有排序规则,也可以修改字符集和排序规则。...列级别 可以在创建表的时候,指定不同的列有不同的字符集和排序规则,也可以修改列的字符集和排序规则mysql> create table test (name varchar(32) character

    3.1K10

    MySQL 创建数据库

    使用 mysqladmin 创建数据库 使用普通用户,你可能需要特定的权限来创建或者删除 MySQL 数据库。...所以我们这边使用root用户登录,root用户拥有最高权限,可以使用 mysql mysqladmin 命令来创建数据库。...实例 以下命令简单的演示了创建数据库的过程,数据名为 test: [root@host]# mysqladmin -u root -p create test 以上命令执行成功后会创建 MySQL 数据库...---- 使用 Python 创建数据库 Python 使用 execute 函数来执行SQL语句达到删除或创建 MySQL 数据库。...://暂时还没有学会如何在微信平台上插入代码的方法,可能下面代码为了能够一次截屏导致可读性较差,请谅解,若有读者指出插入代码的方法就更好了 创建数据库 ?

    10.2K80

    MySQL创建数据库(一)

    一、创建数据库环境 既然我们要使用MySQL数据库,首先需要安装MySQL数据库,具体可以参考MySQL安装教程https://www.cnblogs.com/winton-nfs/p/11524007...下载安装好MySQL数据库环境后就可以正常使用mysql数据库了。...二、创建数据库 数据库就是我们存放数据表的仓库,就好比我们电脑中的文件夹,刚刚安装好的MySQL数据库就像我们刚从数码城买回来的新电脑一样,开机以后发现里面什么也没有(电脑里默认已经安装好的软件不算,不要抬扛...MySQL数据库也是一样,我们连接进入刚刚安装好的MySQL数据库后发现里面也是空的,什么也没有,这时候我们就想着要创建第一个数据库,用来存放后续的一些数据表。...四、总结以上就是MySQL创建数据库以及数据表的基本操作,下节课我们会教大家如何进行MySQL数据插入以及基本的条件查询语句,敬请期待!喜欢我们的内容,欢迎点赞、分享和在看,感谢大家的支持!

    8K20

    mysql创建数据库的步骤_MySQL创建数据表

    第一步:查看当前数据库 show databases; 第二步:创建数据库cjhl_xzf CREATE USER name IDENTIFIED BY ‘cjhl_xzf’; 或者语句:create...是我刚刚建立的数据库,其实在未执行创建一个数据库之前是查不到这个数据库的,也就是在mysql安装文件目录里看不到cjhl_xzf这个文件夹。...sys +———-+ 3 rows in set (0.00 sec) 2、创建一个数据库cjhl_xzf mysql> CREATE DATABASE cjhl_xzf; 注意不同操作系统对大小写的敏感...3、选择你所创建数据库 mysql> USE cjhl_xzf Database changed 此时你已经进入你刚才所建立的数据库cjhl_xzf. 4、 创建一个数据库表 首先看现在你的数据库中存在什么表...创建了一个表后,我们可以看看刚才做的结果,用SHOW TABLES显示数据库中有哪些表: mysql> SHOW TABLES; +———————+ | Tables in menagerie |

    16.2K60
    领券