diff --git a/docs/.vitepress/const/links.ts b/docs/.vitepress/const/links.ts index 599fa8df..af07b0c2 100644 --- a/docs/.vitepress/const/links.ts +++ b/docs/.vitepress/const/links.ts @@ -16,5 +16,6 @@ export const notes = [ { text: 'JavaScript进阶', link: '/note/JavaScriptEnhanced' }, { text: '前端工程化', link: '/note/Front-end Engineering' }, { text: '服务端渲染', link: '/note/SSR' }, - { text: 'React基础', link: '/note/React' } + { text: 'React基础', link: '/note/React' }, + { text: 'MySQL', link: '/note/MySQL' } ] diff --git a/docs/note/MySQL.md b/docs/note/MySQL.md new file mode 100644 index 00000000..21377f44 --- /dev/null +++ b/docs/note/MySQL.md @@ -0,0 +1,296 @@ +# MySQL + +## MySQL基础篇 + +### MySQL简单使用 + +在命令行窗口输入 + +```sh +mysql -uroot -p1234 -hlocalhost -P3306 +``` + +指定用户名为 `root` 密码为 `1234` 连接host为 `localhost` 端口号为 `3306` + +除了以明文方式输入密码,也可以通过另一种方式登录: + +```sh +mysql -u root -p +1234 +``` + +进入mysql命令行工具后,查看所有表: + +```sql +show databases; +``` + +MySQL默认为我们创建了四个表` information_schema` `mysql` `performance_schema` `sys` + +创建一个新的数据库: + +```sql +create database dbtest1; +``` + +使用数据库: + +```sql +use dbtest1; +``` + +创建一张表,初始化`id`与`name`字段: + +```sql +create table employees(id int, name varchar(15)); +``` + +查看表中数据: + +```sql +select * from emoloyees; +``` + +插入一条数据: + +```sql +insert into employees values(1001, 'Tom'); +insert into employees values(1002, 'Jack'); +``` + +当我们向表中插入中文数据时,`5.7`版本的MySQL会报错,而`8.0`版本则不会: + +```sql +insert into employees values(1003, '杰瑞'); +``` + +检查一下表的信息: + +```sql +show create table employees; +``` + +可以发现,表的默认字符集是 `CHARSET=latin1` 拉丁字符集,不包含汉字。 + +查看编码与比较规则: + +百分号`%`表示一个到多个字符 + +```sql +show variables like 'character_%'; +show variables like 'collation_%'; +``` + +若是`5.7`版本,默认的编码字符集为`latin1`,而最新的`8.0`为`utf8`。配置文件可以在`my.ini`中修改 + +删除一个数据库 + +```sql +drop database dbtest1; +``` + +### 基本的SELECT语句 + +#### SQL分类 + +* DDL `DataDefinitionLanguage` 用于定义数据库对象(数据库 表 字段) + * 主要语句关键字包括`CREATE` `DROP` `ALERT`等 +* DML `DataManipulationLanguage` 用于对数据库表中的数据进行增删改查 + * 主要语句关键字包括`INSERT` `DELETE` `UPDATE` `SELECT`等 + * `SELECT`是SQL语言的基础,最为重要 +* DQL `DataQueryLanguage` 用来查询数据库中表的记录 + * 由于查询语句使用的非常频繁,将查询语句单拎出来自成一类 +* DCL `DataControlLanguage` 用来创建数据库用户、控制数据库的访问权限 + * 主要的语句关键字包括`GRANT` `REVOKE` `COMMIT` `ROLLBACK` `SAVEPOINT`等 + +### SQL规则和规范 + +- SQL语句可以单行或多行书写,为了提高可读性,各子句分行写,必要时使用缩进,**以分号结尾** +- 每条命令以 `;` 或 `\g` 或 `\G` 结束 +- 关键字不能被缩写也不能分行 +- 关于标点符号 + - 必须保证所有的()、单引号、双引号是成对结束的 + - 必须使用英文状态下的半角输入方式 + - 字符串型和日期时间类型的数据可以使用单引号(' ')表示 + - 列的别名,尽量使用双引号(" "),而且不建议省略as + +#### SQL大小写规则 + +- MySQL 在 Windows 环境下是大小写不敏感的 +- MySQL 在 Linux 环境下是大小写敏感的 + - 数据库名、表名、表的别名、变量名是严格区分大小写的 + - 关键字、函数名、列名(或字段名)、列的别名(字段的别名) 是忽略大小写的。 +- 推荐采用统一的书写规范: + - 数据库名、表名、表别名、字段名、字段别名等都小写 + - SQL 关键字、函数名、绑定变量等都大写 + +#### 注释书写方法 + +- 单行注释:`--注释内容` 或 `# 注释内容` (MySQL独有) +- 多行注释: /* 注释内容 */ + +#### DDL - 数据库操作 + +* 查询 + * 查询所有数据库 `SHOW DATABASES;` + * 查询当前数据库 `SELECT DATABASE();` +* 创建 + * `CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集] [COLLATE 排序规则];` +* 删除 + * `DROP DATABSE [IF EXISTS] 数据库名` +* 使用 + * `USE 数据库名` + +```shell +mysql -u root -p # 进入mysql +``` + +```sql +SHOW DATABASES; # 展示所有数据库 +CREATE DATABASE custom; # 创建一个名为custom的数据库 +USE custom; # 使用custom数据库 +SELECT DATABASE(); # 当前使用的是custom数据库 +``` + +#### DDL - 表操作 + +##### 创建表 + +**在命令行下,可以在多行内编写一个SQL语句** + +```sql +SHOW TABLES; # 查询当前数据库所有表 +DESC 表名; # 查询 表结构 +SHOW CREATE TABLE 表名; # 查询指定表的建表语句 +``` + +```sql +# 创建表 +CREATE TABLE custom( + param1 type1 [comment ''], + param2 type2 [comment ''], + param3 type3 [comment ''], + param4 type4 [comment ''] +)[comment ''] +``` + +```sql +# 创建一个tb_user表 +create table tb_user( + id int comment '编号', + name varchar(50) comment '姓名', + age int comment '年龄', + gender varchar(1) comment '性别' + ) comment '用户表'; +# 展示数据库中所有表 +show tables; +# 查询表内所有字段 +desc tb_user; +# 展示表的所有信息(包含字段注释、存储引擎、默认字符集、排序规则等信息) +show create table tb_user; +``` + +案例 - 员工信息表 + +```sql +create table emp ( + id int comment '编号', + workno varchar(10) comment '工号', + name varchar(10) comment '姓名', + gender char(1) comment '性别', + age tinyint unsigned comment '年龄', + idcard char(18) comment '身份证号', + entrydate date comment '入职时间' +) comment '员工表'; +``` + +创建成功后,输入`desc emp`查看 + +```shell +mysql> desc emp; ++-----------+------------------+------+-----+---------+-------+ +| Field | Type | Null | Key | Default | Extra | ++-----------+------------------+------+-----+---------+-------+ +| id | int | YES | | NULL | | +| workno | varchar(10) | YES | | NULL | | +| name | varchar(10) | YES | | NULL | | +| gender | char(1) | YES | | NULL | | +| age | tinyint unsigned | YES | | NULL | | +| idcard | char(18) | YES | | NULL | | +| entrydate | date | YES | | NULL | | ++-----------+------------------+------+-----+---------+-------+ +7 rows in set (0.00 sec) +``` + +##### 修改表 + +```sql +# 添加一个字段 +alter table 表名 add 字段名 类型(长度) [comment ''] +# 修改一个字段 +alter table 表名 modify 旧字段名 新字段名 类型(长度) [comment ''] +# 删除一个字段 +alter table 表名 drop 字段名 +# 修改表名 +alter table 表名 rename to 新表名 +``` + +```sql +alter table emp add nickname varchar(20) comment '昵称' +alter table emp modify nickname username varchar(30) +alter table emp drop username +alter table emp rename to employee +``` + +### MySQL数据类型 + +#### 数值类型 + +在定义字段时,通过关键字`UNSIGNED`确定其`无符号 / 有符号` + +| 类型 | 大小 | 范围(有符号) | 范围(无符号) | 用途 | +| :----------- | :--------------------------------------- | :----------------------------------------------------------- | :----------------------------------------------------------- | :-------------- | +| TINYINT | 1 Bytes | (-128,127) | (0,255) | 小整数值 | +| SMALLINT | 2 Bytes | (-32 768,32 767) | (0,65 535) | 大整数值 | +| MEDIUMINT | 3 Bytes | (-8 388 608,8 388 607) | (0,16 777 215) | 大整数值 | +| INT或INTEGER | 4 Bytes | (-2 147 483 648,2 147 483 647) | (0,4 294 967 295) | 大整数值 | +| BIGINT | 8 Bytes | (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) | (0,18 446 744 073 709 551 615) | 极大整数值 | +| FLOAT | 4 Bytes | (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) | 0,(1.175 494 351 E-38,3.402 823 466 E+38) | 单精度 浮点数值 | +| DOUBLE | 8 Bytes | (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 双精度 浮点数值 | +| DECIMAL | 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 | 依赖于M和D的值 | 依赖于M和D的值 | 小数值 | + +#### 字符串类型 + +| 类型 | 大小 | 用途 | +| :--------- | :-------------------- | :------------------------------ | +| CHAR | 0-255 bytes | 定长字符串 | +| VARCHAR | 0-65535 bytes | 变长字符串 | +| TINYBLOB | 0-255 bytes | 不超过 255 个字符的二进制字符串 | +| TINYTEXT | 0-255 bytes | 短文本字符串 | +| BLOB | 0-65 535 bytes | 二进制形式的长文本数据 | +| TEXT | 0-65 535 bytes | 长文本数据 | +| MEDIUMBLOB | 0-16 777 215 bytes | 二进制形式的中等长度文本数据 | +| MEDIUMTEXT | 0-16 777 215 bytes | 中等长度文本数据 | +| LONGBLOB | 0-4 294 967 295 bytes | 二进制形式的极大文本数据 | +| LONGTEXT | 0-4 294 967 295 bytes | 极大文本数据 | + +**注意**:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。 + +CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。**CHAR性能更优** + +BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。 + +BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。 + +有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。 + +#### 日期时间类型 + +| 类型 | 大小 ( bytes) | 范围 | 格式 | 用途 | +| :-------- | :------------ | :----------------------------------------------------------- | :------------------ | :----------------------- | +| DATE | 3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | 日期值 | +| TIME | 3 | '-838:59:59'/'838:59:59' | HH:MM:SS | 时间值或持续时间 | +| YEAR | 1 | 1901/2155 | YYYY | 年份值 | +| DATETIME | 8 | 1000-01-01 00:00:00/9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值 | +| TIMESTAMP | 4 | 1970-01-01 00:00:00/2038结束时间是第 **2147483647** 秒,北京时间 **2038-1-19 11:14:07**,格林尼治时间 2038年1月19日 凌晨 03:14:07 | YYYYMMDD HHMMSS | 混合日期和时间值,时间戳 | +