docs: MySQL note update

This commit is contained in:
ZiuChen 2023-04-27 00:56:01 +08:00
parent 9e57a2cff3
commit 9307a506b5
2 changed files with 298 additions and 1 deletions

View File

@ -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' }
]

296
docs/note/MySQL.md Normal file
View File

@ -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 | (-128127) | (0255) | 小整数值 |
| SMALLINT | 2 Bytes | (-32 76832 767) | (065 535) | 大整数值 |
| MEDIUMINT | 3 Bytes | (-8 388 6088 388 607) | (016 777 215) | 大整数值 |
| INT或INTEGER | 4 Bytes | (-2 147 483 6482 147 483 647) | (04 294 967 295) | 大整数值 |
| BIGINT | 8 Bytes | (-9,223,372,036,854,775,8089 223 372 036 854 775 807) | (018 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-383.402 823 466 351 E+38) | 0(1.175 494 351 E-383.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-3081.797 693 134 862 315 7 E+308) | 0(2.225 073 858 507 201 4 E-3081.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 | 混合日期和时间值,时间戳 |