哈喽大家好,本次是MySQL数据库原理系列第九期 ⭐本期内容:字符集与校对集 系列专栏:MySQL数据库 还请大家多多指教呀~ 欢迎大佬指正,一起学习,一起加油!...---- 文章目录 字符集与校对集概述 字符集 常用字符集 校对集 字符集与校对集的设置 MySQL环境 数据库 数据表 字段 总结 ---- 字符集与校对集概述 字符集 字符指计算机中保存的各种文字和符号...latin1 1字节 西欧字符、希腊字符等 gbk 2字节 简体和繁体中文、日文、韩文等 utf8 3字节 世界上大部分国家的文字 单字符占用的存储空间越多,所支持的语言越多 校对集 MySQL中提供了许多校对集...字符集与校对集的设置 MySQL环境 输入如下命令可以查看与字符集相关的变量。...数据库 在创建数据库时设定字符集和校对集的语法如下: [default] character set [=] charset_name [default] collate [=] collation_name
MySQL服务器能够支持多种字符集。...可以使用SHOW CHARACTER SET语句列出可用的字符集: mysql> SHOW CHARACTER SET; +----------+----------------------------...任何一个给定的字符集至少有一个校对规则。它可能有几个校对规则。 要想列出一个字符集的校对规则,使用SHOW COLLATION语句。...例如,要想查看latin1(“西欧ISO-8859-1”)字符集的 校对规则,使用下面的语句查找那些名字以latin1开头的 校对规则: mysql> SHOW COLLATION LIKE 'latin1%..._spanish_ci 现代西班牙 校对规则一般有这些特征: ·两个不同的字符集不能有相同的校对规则。
实际的应用访问来说,存在着客户端和服务器之间交互的字符集和校对规则的设置。...对于客户端和服务器的交互操作,MySQL提供了3个不同的参数:character_set_clinet,character_set_connection和character_set_result,分别代表客户端...通常情况下,不会单个设置这3个参数,可以通过以下命令: SET NAMES ***; 来设置连接的字符集和校对规则,这个命令可以同时修改这3个参数的值。...使用这个方法修改连接的字符集和校对规则,需要应用每次连接数据库都执行这个命令。...另一个更简便的方法,在my.cnf中设置以下语句: 【mysql】 default-character-set=utf8 这样服务器启动后,所有连接默认就是使用utf8字符集进行连接的,而不需要在程序中再执行
比较的最简单的方法是查找编码:‘A’为0,‘B’为1。因为0 小于1,我们可以说‘A’小于‘B’。我们做的仅仅是在我们的字符集上应用了一个 校对规则。...校对规则是一套规则(在这种情况下仅仅是一套规则):“对编码进行比较。”我们称这种全部可能的规则中的最简单的 校对规则为一个binary(二元)校对规则。...校对规则的一种)。...MySQL5.1能够做这些事情: ·使用多种字符集来存储字符串 ·使用多种校对规则来比较字符串 ·在同一台服务器、同一个数据库或甚至在同一个表中使用不同字符集或校对规则来混合字符串 ·允许定义任何级别的字符集和校对规则...在这些方面,MySQL5.1不仅比MySQL4.1以前的版本灵活得多,而且比其它大多数数据库管理系统超前许多。
那么mysql中大小写敏感是如何控制的;数据库名,表名,字段名这些字典对象以及字段值的大小敏感是如何控制的;以及校验规则与索引的关系,这是本文要讨论的内容。...在mysql中,数据库对应数据目录中的目录。数据库中的每个表至少对应数据库目录中的一个文件(也可能是多个,取决于存储引擎)。因此,所使用操作系统的大小写敏感性决定了数据库名和表名的大小写敏感性。...MySQL将所有表名转换为小写在存储和查找表上。该行为也适合数据库名和表的别名。该值为Windows的默认值。...字段值的大小写由mysql的校对规则来控制。提到校对规则,就不得不说字符集。字符集是一套符号和编码,校对规则是在字符集内用于比较字符的一套规则,比如定义'A'的关系的规则。...没关系,mysql提供了collate语法,通过指定utf8_bin校对规则即可。 ?
字符集指的是一种从二进制编码到某类字符符号的映射。校对规则则是指某种字符集下的排序规则。 在 MySQL 中,每一种字符集都会对应一系列的校对规则。...MySQL 采用的是类似继承的方式来指定字符集的默认值,每个数据库以及每张数据表都有自己的默认值,他们逐层继承。...比如:某个库中所有表的默认字符集,将是该数据库所指定的字符集(这些表在没有指定字符集的情况下,才会采用默认字符集) PS:整理自《Java 工程师修炼之道》 MySQL 索引使用的数据结构主要有 BTree...MySQL 的 BTree 索引使用的是 B 树中的 B+Tree,但在两种主要的存储引擎里,它们的实现方式是不同的。 MyISAM: B+Tree 叶节点的 data 域,存放的是数据记录的地址。...而其余的索引都作为辅助索引,辅助索引的 data 域,存储的是相应记录主键的值,而不是地址,这也是和 MyISAM 不同的地方。
1.8 补充知识 每次执行指令要进入相应的目录中,麻烦,可以通过环境变量简化操作。 1.8.1 环境变量配置 我的电脑右键——属性——高级 ?...将mysql指令目录地址添加到环境变量的Path值中 ? 这时候就可以在任意目录下使用mysql指令 ?...原理: 1、输入指令后,首先在当前目录下查找,如果当前目录下找不到,就到环境变量的Path中查找 2、Path中有很多目录,从前往后查找 1.8.2 校对集 1、概念:在某种字符集下,字符之间的比较关系...比如赵钱孙李大小关系,不同的标准关系不一样 2、校对集依赖与字符集,不同的字符集的的比较规则不一样,如果字符集更改,校对集也重新定义。 3、不同的校对集对同一字符序列比较的结果是不一致的。...4、 可以在定义字符集的同时定义校对集、 语法: collate = 校对集 例题: 定义两个表,相同字符集不同校对集 mysql> create table stu1( -> name char
上一篇呢,从理论上介绍了MYSQL字符集和校对规则是什么以及如何正确的使用字符集;关于第一部分的内容可参考:深入理解MySQL字符集及校对规则(一) 下面这部分呢,主要介绍MySQL字符编码转换原理以及字符集转化流程案例测试...转换为内部操作字符集 确定步骤: –使用每个数据字段的CHARACTER SET设定值; –若上述值不存在,则使用对应数据表的DEFAULT CHARACTER SET设定值; –若上述值不存在,则使用对应数据库的...(一般在数据库实现字符集即可,表和列都默认采用数据库的字符集) 4、修改表的字符集 mysql> alter table table_name character set xxx; 只修改表的字符集,影响后续该表新增列的默认定义...、character_set_connection相同 (4)所有的字符集转换都发生在数据库端 综述: 1、建立数据库的时候注意字符集(gbk、utf8); 2、连接数据库以后,无论是执行dml还是select...三、MYSQL字符编码转化流程测试 使用实验来进一步说明MySQL服务器字符集以及连接字符集之间的作用以及关系。
下面针对mysql字符集以及校对规则做一个详细的介绍说明,针对MYSQL字符集,将从两个方面介绍: 第一部分:MYSQL字符集和校对规则是什么以及如何正确的使用字符集; 第二部分:MySQL字符编码转换原理以及字符集转化流程案例测试...MySQL中的字符集都对应着一个默认的校对规则(COLLATION),当然一个字符集也可能对应多个校对规则,但是两个不同的字符集不能对应同一个规则。...二、校对规则collation校对 查看数据库支持的所有字符集(charset): mysql> show character set; 查看数据库支持的所有校对规则 mysql> show collation...; 查看当前字符集和校对规则设置 mysql> show variables like ‘collation_%’; 以collation_开头的都是用来做列校对规则的。...三、四个层次的字符集设置 下面以MySQL中字符集和校对规则的继承规则进行四个层次的字符集设置(服务器、数据库、表、列)。
做新年规划的时候,我说过要翻译C++常用类的参考。C++的参考,其实别人已经翻译完了,只是部分内容需要校对。由于网站结构中大量使用了模板,同一个函数只需要翻译一个地方,所以四天就弄完了。...而且我没有翻译函数层级的页面,所以比较快。 C++的参考其实最需要翻译。因为C++为了填C继承过来的坑,标准库增加了很多用于替代的设施。...而国内的教程更新缓慢,这份参考如果不翻译,我估计到了2020年也不会完全普及。...以下是校对完成的类,希望大家继续参与: unique_ptr shared_ptr weak_ptr duration function... pair tuple 字符串 basic_string Null结尾的单字节字符串 Null结尾的多字节字符串 Null结尾的宽字符串 容器 array vector
如何借助 ChatGPT 和 OpenAI API 撬开文档校对的大门?希望能为大家提供一个可行的思路。...多语言:对于上线国际站的产品而言,不仅工作量翻倍,无论是用词还是拼写,都会为校对工作带来困难。...实际上不止产品文档,日常的 API 文档、公告、邮件、汇报材料等等都会涉及到上述问题,且必须想办法解决。 总的来说,文档校对是一件人力投入很高、仅满足“基本需求”的任务。...这个时候我们就得借助一些代码,通过调用 OpenAI API 来完成多篇文档校对的任务。...已实现的效果见下图,不但能检查出错别字,还会对其他内容有优化建议。虽然但是,仍有诸多优化点,以更好地完成文档校对的任务,但我目前相信沿着这条路前进准没错。
ls /var/lib/mysql中的内容是上一个mysql数据库中所残留的数据,MySQL服务在卸载的时候,默认不会将数据删除掉,这些数据我们可以不用管,他们并不影响我们后续MySQL服务的安装和使用...H2: 是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中 上面的数据库管理系统中,国内用的最多的还是MySQL,银行金融业用oracle比较多,MySQL的生态很完整,...三、MySQL操作库 1.库结构的CURD操作 查看MySQL中所有的数据库:show databases; 创建数据库的指令和显示创建数据库时的指令 !...数据库的重命名MySQL是不支持的,并且这是非常合理的,因为数据库的名字是量级很重的,一旦数据库的名字发生改变,则上层所有使用数据库的代码都需要做出调整,代价特别大,所以一般在项目前期讨论协商的时候,一定要确定好数据库的命名等工作...约束的唯一目的其实就是为了保证数据库中数据的有效性,可预期性和完整性,一旦插入的数据不符合表约束,则MySQL直接拦截数据的插入,倒逼程序员向数据库中插入有效的数据。让数据库中的数据都是符合约束的。
,因为索引只能提升部分数据的查询,查询的数据一旦涉及到索引中没有包含的列字段,则此时就无法使用B+索引结构来优化查询的速度,数据库系统只能遍历整个表的所有行来进行查找,这会大大降低查询速度。...除此之外,实际公司使用的MySQL数据库,存储的数据最少也几百万条记录打底,一旦全列查询,则查询结果会疯狂刷屏到显示器上,看也没法看,而且还有可能导致mysqld服务卡死,所以平常我们自己敲一些简单的数据库...查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示 6. 对未知表进行查询时,最好进行分页显示,这样可以避免表中数据过大时,导致查询全表数据致使数据库卡死。...MySQL一定是不支持的。...,要加单引号,防止别名与MySQL中的关键字冲突。
文章目录 Mysql使用时的注意事项 库的操作 数据类型 数值类型 日期和时间类型 字符串类型 表的操作 表中数据的增删改查基础 插入数据:insert 查询数据:select 条件查询 修改数据:update...删除数据:delete Mysql使用时的注意事项 每日一条数据库操作语句都应该以分号 ;结尾,因为mysql支持换行操作 mysql数据库对大小写不敏感,大小写皆可,通常关键字使用大写表示 mysql...数据库中哭的名称应该以英文字符或者一些符号起始,但是不允许以数字起始 mysql数据库中哭的名称、表的名称、字段的名称都不能使用mysql关键字,比如create、database;如果非要使用,那就用反引号括起来...,则创建 删除库:drop database 库名称; 选择使用数据库:use 库名称; 显示当前使用的数据库:select database(); 数据类型 数值类型 MySQL支持所有标准SQL...作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。
核心军规 尽量不在数据库做运算 控制单表数据量 纯INT不超过10M条,含Char不超过5M条 保持表身段苗条 平衡范式和冗余 拒绝大SQL,复杂事务,大批量任务 字段类军规 用好数值字段,尽量简化字段位数...把字符转化为数字 优先使用Enum或Set 避免使用Null字段 少用并拆封Text/Blob 不在数据库中存图片 索引类军规 谨慎合理添加索引 字符字段必须建立前缀索引?...UTF8MB4 for by 可能还有人不知道,MySQL 数据库的字符集,要用 utf8mb4,而不是utf8。...因为MySQL的utf8不是真正的UTF-8,只支持最多三个字节的字符。真正的UTF-8可能会出现四个字节的字符。...MySQL 从来没有修复这个 Bug,而是使用另外的解决方法:真正的UTF-8字符集用 utf8mb4的名字提供。
关系型数据库:对于存储的数据,格式上有严格要求。类似于excle表格的方式来存储的。例如:MySQL,Oracle,SQL Server,SQLite....有事性能更快,同时也更好的能适应分布式环境(高并发,大数据,分布式,微服务) 关系型数据库和非关系型数据库的区别: MySQL的介绍 MySQL是一个客户端服务器结构的程序。...关系型数据库具体组织数据的格式/结构 数据库的基本操作 数据库的操作 指的是MySQL服务器上存在的多个数据集合。...查看所有数据库 show databases; 注意databases是复数形式。 选中指定的数据库 一个MySQL服务器上,数据库可以有很多个。...所以在操作删除数据库的时候一定要做到谨慎。 常用数据类型 数值类型 在MySQL的数据类型中,数据库里的表,每一个列都是带有类型的(例如整数,浮点数,字符串)。
目录Mysql约束(constraint)基本介绍主键约束(primary key)自增长约束(auto_increment)非空约束(not null)唯一性约束(unique)默认约束(default...)零填充约束(zerofill)----图片Mysql约束(constraint)基本介绍 MySQL数据库通过约束(constraints)防止无效的数据进入到数据库中,以保护数据的实体完整性...MySQL中主要有六种约束,分别是:主键约束(primary key),非空约束(not null),自增长约束(auto_increment),默认约束(default) ,零填充约束(zerofill...auto_increment约束字段的最大值受该字段的数据类型约束,如果达到上限,auto_increment就会失效。...,会在该值的前面补上相应的0。
专栏持续更新中:MySQL详解 一、背景 先要从 InnoDB 的索引实现说起,InnoDB 有两大类索引: 聚集索引(clustered index) 普通索引 (secondary index...InnoDB 普通索引 的叶子节点存储主键值。 注意:只有 InnoDB 普通索引才存储主键值,MyISAM 的二级索引都是直接指向数据块的。...通俗的讲就是,如果索引的列在 select 所需获得的列中(因为在 mysql 中索引是根据索引列的值进行排序的,所以索引节点中存在该列中的部分值)或者根据一次索引查询就能获得记录就不需要回表,如果 select...所需获得列中有大量的非索引列,索引就需要到表中找到相应的列的信息,这就叫回表。...四、解决办法 使用覆盖索引可以解决上面所说的回表的问题。
五、MySQL的执行顺序 MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操作,最后执行的是LIMIT操作。...其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对用户来说是透明的,但是只有最后一个虚拟的表才会被作为结果返回。...如果没有在语句中指定某一个子句,那么将会跳过相应的步骤。 ? 下面我们来具体分析一下查询处理的每一个阶段 FORM: 对FROM的左边的表和右边的表计算笛卡尔积。...JOIN: 如果指定了OUTER JOIN(比如left join、 right join),那么保留表中未匹配的行就会作为外部行添加到虚拟表VT2中,产生虚拟表VT3, rug from子句中包含两个以上的表的话...只有符合的记录才会被插入到虚拟表VT4中。 GROUP BY: 根据group by子句中的列,对VT4中的记录进行分组操作,产生VT5.
DB DataBase :数据库 依照某种数据模型进行组织并存放到存储器的数据集合 DBMS DataBase Manager System :数据库管理系统 用来操作和管理数据库的大型服务软件...DBS DataBase System :数据库系统 即DB+DBMS指带有数据库并整合了数据库管理软件的计算机系统 2.E-R数据模型 3.常见数据库软件服务商 甲骨文:MYSQL...5.特点及应用 mysql的主要特点: -适用于中小规模、关系型数据库系统 -支持Linux/UNIX、Windows等多种操作系统 -使用C和C++编写,可移植性强 -通过API支持Python...[确定] 2.删除5.1的配置文件和数据库文件 [root@svr5 ~]# rm -rf /etc/my.cnf [root@svr5 ~]# rm -rf /var/lib/mysql/* 3.卸载...需要注意的是这里的root用户不是Linux系统的root用户,而是mysql数据库的管理员root。
领取专属 10元无门槛券
手把手带您无忧上云