mirror of
https://github.com/ZiuChen/ZiuChen.github.io.git
synced 2025-08-17 06:49:38 +08:00
docs: MySQL note update
This commit is contained in:
parent
7f4c9960e9
commit
abe1735658
@ -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
296
docs/note/MySQL.md
Normal 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 | (-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 | 混合日期和时间值,时间戳 |
|
||||
|
Loading…
x
Reference in New Issue
Block a user