目录
库的操作
数据库创建
数据库编码集
数据库删除
数据库修改
数据库查询
数据库备份
表的操作
表的创建
查询表
删除表
修改表
这里先声明一下,这篇文章主要是讲数据库表的定义操作,也就是 DDL,只要是对数据库以及表结构操作的 SQL
数据库的创建,其实在之前我们浅浅的提过创建数据库。
CREATE DATABASE database_name [character set 字符集编码 collate 校验集];
一般 mysql 里面关键字用大写,但是小写也支持
database_name 是数据库名
[ ] 里面的是可选项
上面就是创建数据库的语法,我们先不看可选项,我们先简单的创建一下数据库。
示例:
创建一个 d1 的数据库。
mysql> create database d1;
Query OK, 1 row affected (0.00 sec)
创建好该数据库后,在 /var/lib/mysql 目录下一定会生成一个 d1 的目录,而创建数据库的本质就是在特定的目录下创建一个目录,而帮我们创建该目录的就是 mysqld(也就是 mysql 服务)。
上面就是默认的创建,等创建好后,该数据库的编码就是按照我们的配置文件里面来的。
先说一下什么是编码,编码就是当一个文本存到计算机中那么是按照什么格式存储的,就可以这样简单的理解。
在mysql中其实有两个编码集:
字符集:当存储的时候按照字符集的格式存储
校验集:当数据库里面的数据比较或者读取的时候按照校验集
所以当我们创建数据库的时候,字符集和校验集一定要是相对应的。
上面的编码集可以简单理解一下,就是如果我们用中文来写文章,那么其他人也必须要中中文来理解这篇文章,如果用其他语言的话,那么就会看不懂或者理解错误。
编码集在数据库创建的时候也可以设置,如果不设置的话就会按照配置文件里面的默认来设置。
当前 mysql 的默认字符集和编码集分别是多少?
字符集:
mysql> show variables like 'character_set_database';
+------------------------+-------+
| Variable_name | Value |
+------------------------+-------+
| character_set_database | utf8 |
+------------------------+-------+
1 row in set (0.00 sec)
校验集:
mysql> show variables like 'collation_database';
+--------------------+-----------------+
| Variable_name | Value |
+--------------------+-----------------+
| collation_database | utf8_general_ci |
+--------------------+-----------------+
1 row in set (0.00 sec)
上面就是当前创建数据库的默认编码集。
当前mysql 中所有的编码集合
字符集:
show character set;
mysql> show character set;
+----------+---------------------------------+---------------------+--------+
| Charset | Description | Default collation | Maxlen |
+----------+---------------------------------+---------------------+--------+
| big5 | Big5 Traditional Chinese | big5_chinese_ci | 2 |
| dec8 | DEC West European | dec8_swedish_ci | 1 |
| cp850 | DOS West European | cp850_general_ci | 1 |
| hp8 | HP West European | hp8_english_ci | 1 |
| koi8r | KOI8-R Relcom Russian | koi8r_general_ci | 1 |
| latin1 | cp1252 West European | latin1_swedish_ci | 1 |
| latin2 | ISO 8859-2 Central European | latin2_general_ci | 1 |
| swe7 | 7bit Swedish | swe7_swedish_ci | 1 |
| ascii | US ASCII | ascii_general_ci | 1 |
| ujis | EUC-JP Japanese | ujis_japanese_ci | 3 |
| sjis | Shift-JIS Japanese | sjis_japanese_ci | 2 |
| hebrew | ISO 8859-8 Hebrew | hebrew_general_ci | 1 |
| tis620 | TIS620 Thai | tis620_thai_ci | 1 |
| euckr | EUC-KR Korean | euckr_korean_ci | 2 |
| koi8u | KOI8-U Ukrainian | koi8u_general_ci | 1 |
| gb2312 | GB2312 Simplified Chinese | gb2312_chinese_ci | 2 |
| greek | ISO 8859-7 Greek | greek_general_ci | 1 |
| cp1250 | Windows Central European | cp1250_general_ci | 1 |
| gbk | GBK Simplified Chinese | gbk_chinese_ci | 2 |
| latin5 | ISO 8859-9 Turkish | latin5_turkish_ci | 1 |
| armscii8 | ARMSCII-8 Armenian | armscii8_general_ci | 1 |
| utf8 | UTF-8 Unicode | utf8_general_ci | 3 |
| ucs2 | UCS-2 Unicode | ucs2_general_ci | 2 |
| cp866 | DOS Russian | cp866_general_ci | 1 |
| keybcs2 | DOS Kamenicky Czech-Slovak | keybcs2_general_ci | 1 |
| macce | Mac Central European | macce_general_ci | 1 |
| macroman | Mac West European | macroman_general_ci | 1 |
| cp852 | DOS Central European | cp852_general_ci | 1 |
| latin7 | ISO 8859-13 Baltic | latin7_general_ci | 1 |
| utf8mb4 | UTF-8 Unicode | utf8mb4_general_ci | 4 |
| cp1251 | Windows Cyrillic | cp1251_general_ci | 1 |
| utf16 | UTF-16 Unicode | utf16_general_ci | 4 |
| utf16le | UTF-16LE Unicode | utf16le_general_ci | 4 |
| cp1256 | Windows Arabic | cp1256_general_ci | 1 |
| cp1257 | Windows Baltic | cp1257_general_ci | 1 |
| utf32 | UTF-32 Unicode | utf32_general_ci | 4 |
| binary | Binary pseudo charset | binary | 1 |
| geostd8 | GEOSTD8 Georgian | geostd8_general_ci | 1 |
| cp932 | SJIS for Windows Japanese | cp932_japanese_ci | 2 |
| eucjpms | UJIS for Windows Japanese | eucjpms_japanese_ci | 3 |
| gb18030 | China National Standard GB18030 | gb18030_chinese_ci | 4 |
+----------+---------------------------------+---------------------+--------+
41 rows in set (0.01 sec)
校验集:
show collation;
mysql> show collation;
+--------------------------+----------+-----+---------+----------+---------+
| Collation | Charset | Id | Default | Compiled | Sortlen |
+--------------------------+----------+-----+---------+----------+---------+
| gbk_chinese_ci | gbk | 28 | Yes | Yes | 1 |
| gbk_bin | gbk | 87 | | Yes | 1 |
| latin5_turkish_ci | latin5 | 30 | Yes | Yes | 1 |
| latin5_bin | latin5 | 78 | | Yes | 1 |
| armscii8_general_ci | armscii8 | 32 | Yes | Yes | 1 |
| armscii8_bin | armscii8 | 64 | | Yes | 1 |
| utf8_general_ci | utf8 | 33 | Yes | Yes | 1 |
| utf8_bin | utf8 | 83 | | Yes | 1 |
| utf8_unicode_ci | utf8 | 192 | | Yes | 8 |
| utf8_icelandic_ci | utf8 | 193 | | Yes | 8 |
| utf8_latvian_ci | utf8 | 194 | | Yes | 8 |
| utf8_romanian_ci | utf8 | 195 | | Yes | 8 |
| utf8_slovenian_ci | utf8 | 196 | | Yes | 8 |
| utf8_polish_ci | utf8 | 197 | | Yes | 8 |
| utf8_estonian_ci | utf8 | 198 | | Yes | 8 |
| utf8_spanish_ci | utf8 | 199 | | Yes | 8 |
| utf8_swedish_ci | utf8 | 200 | | Yes | 8 |
| utf8_turkish_ci | utf8 | 201 | | Yes | 8 |
| utf8_czech_ci | utf8 | 202 | | Yes | 8 |
| utf8_danish_ci | utf8 | 203 | | Yes | 8 |
| utf8_lithuanian_ci | utf8 | 204 | | Yes | 8 |
| utf8_slovak_ci | utf8 | 205 | | Yes | 8 |
| utf8_spanish2_ci | utf8 | 206 | | Yes | 8 |
| utf8_roman_ci | utf8 | 207 | | Yes | 8 |
| utf8_persian_ci | utf8 | 208 | | Yes | 8 |
| utf8_esperanto_ci | utf8 | 209 | | Yes | 8 |
| utf8_hungarian_ci | utf8 | 210 | | Yes | 8 |
| utf8_sinhala_ci | utf8 | 211 | | Yes | 8 |
| utf8_german2_ci | utf8 | 212 | | Yes | 8 |
| utf8_croatian_ci | utf8 | 213 | | Yes | 8 |
| utf8_unicode_520_ci | utf8 | 214 | | Yes | 8 |
| utf8_vietnamese_ci | utf8 | 215 | | Yes | 8 |
| utf8_general_mysql500_ci | utf8 | 223 | | Yes | 1 |
| gb18030_chinese_ci | gb18030 | 248 | Yes | Yes | 2 |
| gb18030_bin | gb18030 | 249 | | Yes | 1 |
| gb18030_unicode_520_ci | gb18030 | 250 | | Yes | 8 |
+--------------------------+----------+-----+---------+----------+---------+
222 rows in set (0.00 sec)
上面的校验集太多了,所以只截取了一部分。
前面说了,如果创建数据库没有带编码集的话,那么就会按照默认来,如果设置了那么就会就近原则,按照设置的。
下面我们看一下如何在创建数据库的时候设置编码集。
mysql> create database d1 character set utf8 collate utf8_general_ci;
Query OK, 1 row affected (0.00 sec)
上面就是设置了编码集,其实还有一种设置编码集的方法。
mysql> create database d2 charset=utf8 collate=utf8_general_ci;
Query OK, 1 row affected (0.00 sec)
上面这两种设置的方法都可以,但是其实一般我们都是不写的,因为我们都设置在了配置文件里面。
那么既然设置了编码集,要怎么查看呢?
在 /var/lib/mysql 目录下,存的是创建好的数据库,当创建好一个数据库后都会有一个默认的文件 db.opt 文件,而该文件里面写的就是默认的编码集。
[root@slave0 mysql]# cat ./d1/db.opt
default-character-set=utf8
default-collation=utf8_general_ci
[root@slave0 mysql]# cat ./d2/db.opt
default-character-set=utf8
default-collation=utf8_general_ci
上面是刚才创建的两个数据库,以及里面的编码集就是刚才创建数据库时候设置的,既然如此,我们在看一下如果没有设置编码集默认的编码集是什么。
创建数据库:
mysql> create database d3;
Query OK, 1 row affected (0.00 sec)
查看默认编码集:
[root@slave0 mysql]# cat ./d3/db.opt
default-character-set=utf8
default-collation=utf8_general_ci
这里看到默认的编码集也是 utf8
下面设置一个其他的编码集,这样看起来明显一点,想要设置其他的编码集可以在上面所有的编码中找一对。
这里我们设置编码集为 gbk 和 gbk_chinese_ci
mysql> create database d4 charset=gbk collate=gbk_chinese_ci;
Query OK, 1 row affected (0.00 sec)
查看编码集:
[root@slave0 mysql]# cat ./d4/db.opt
default-character-set=gbk
default-collation=gbk_chinese_ci
这里看到也是相对应的。
上面说了数据库的创建,那么也说一下数据库的删除,数据库的删除是比较简单的。
drop database database_naeme;
这里就不作示范了,但是这里要说明一点,如果数据库删除了的话,那么该数据库里面的数据也是一同被删除了,而且删除后就无法找回了,所以这里并不建议随便删除数据库。
数据库修改可以修改数据库的编码集,mysql 在之前的版本是可以修改数据库的名称的,但是后来不支持了。而且数据库也不建议随便修改。
alter database database_name charset=字符集 collate=校验集;
修改 d1 数据库:
mysql> alter database d1 charset=gbk collate=gbk_chinese_ci;
Query OK, 1 row affected (0.00 sec)
查看默认编码:
[root@slave0 mysql]# cat ./d1/db.opt
default-character-set=gbk
default-collation=gbk_chinese_ci
上面就是修改,而且修改后在查一下也是可以的。
show databases;
上面这条是查询所有的数据库
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| d1 |
| d2 |
| d3 |
| d4 |
| mysql |
| performance_schema |
| sys |
+--------------------+
8 rows in set (0.00 sec)
除了可以查询当前所有的数据库,还可以查询当前所在的数据库
select database();
上面就是通过 database() 函数 来查询当前所在数据库。
mysql> select database();
+------------+
| database() |
+------------+
| NULL |
+------------+
1 row in set (0.00 sec)
由于我们当前并没有在其中某一个数据库中,所以我们需要进入其中任意一个数据库,然后查询。
mysql> use d1;
Database changed
mysql> select database();
+------------+
| database() |
+------------+
| d1 |
+------------+
1 row in set (0.00 sec)
上面 use 就是选择数据库,而数据库选择也不需要退出其他的数据库,可以直接use,当进入 d1 数据库后,查询得知当前在 d1 数据库。
上面就是库的操作,增、删、查、改。
数据库备份可以防止数据丢失。
mysqldump -P 端口号 -u 用户 -p 密码 -B 数据库名 表名 > /路径/ file_name.sql
这样就是对数据库进行备份,这时候我们还需要输入数据库的密码,如果没有密码可以不输入,直接回车,也可以直接不带 -p 选项,然后备份到一个目录下一个 file_name.sql 的文件。
把 d1 备份:
[root@slave0 MySql]# mysqldump -P3306 -uroot -p -B d1 > /MySql/d1.sql
Enter password:
下面我们看一下备份里面的数据
[root@slave0 MySql]# cat d1.sql
-- MySQL dump 10.13 Distrib 5.7.43, for Linux (x86_64)
--
-- Host: localhost Database: d1
-- ------------------------------------------------------
-- Server version 5.7.43
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
--
-- Current Database: `d1`
--
CREATE DATABASE /*!32312 IF NOT EXISTS*/ `d1` /*!40100 DEFAULT CHARACTER SET gbk */;
USE `d1`;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
-- Dump completed on 2023-08-21 11:54:09
其实数据库的备份里面存储的并不是数据,而是对该数据库的一些操作,由于我们没有对该数据库做什么操作所以里面也没有什么内容。
恢复备份
source 路径
恢复备份只需要 source 然后后面跟备份路径就可以了,到时候 mysql 会自动执行里面原本的操作然后恢复数据。
恢复 d1 数据库:
mysql> source /MySql/d1.sql
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 1 row affected (0.00 sec)
Database changed
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
查看是否恢复:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| d1 |
| d2 |
| d3 |
| d4 |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
9 rows in set (0.00 sec)
这里看到 d1 数据库已经恢复到数据库了。
前面我们说的树库的操作,那么当我们会对库进行操作后,我们当然也是需要会对表进行操作的。
而表的操作也是属于 DDL 的一部分。
表的创建用的关键字也是 create 因为这些操作都属于 DDL 所以关键字都基本一样。
create table [if not exists] table_name (
filed1 datatype [comment '该字段描述'],
filed2 datatype [comment '该字段描述'],
filed3 datatype [comment '该字段描述']
) [character set 字符集 collate 校验集 engine 索引];
create table 创建表
filed 列名
datatype 数据类型
comment 该字段的描述
if not exists 表示如果该表不存在就创建,否则不创建
[ ]可选项
下面我们自己创建一张表 table表:
mysql> create table table1(
-> name varchar(10),
-> id int);
Query OK, 0 rows affected (0.01 sec)
上面就是创建一张表,我们没有带 comment 等字段,也没有带编码集,如果没有带编码集的话,那么就是根据数据库的编码集,如果带了那么就是按照自己设置的编码集。
那么我们把这些字段都带上,然后创建一个 user 表:
mysql> create table if not exists user(
-> id int comment '用户 ID',
-> name varchar(12) comment '用户名',
-> birthday date comment '用户生日'
-> )character set utf8 collate utf8_general_ci engine innodb;
Query OK, 0 rows affected (0.01 sec)
这里介绍一下这些内容,首先 id、name 、birthday 等这些就是列名,而后面跟的就是类型,这些类型和语言里面的是有一些差别的,我们后面会专门介绍。
这样就是创建一张表。
经过刚才创建表,我们现在看一下查询表
show tables;
show tables 这样查的表是该数据库里面所有的表。
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| table1 |
| user |
+----------------+
2 rows in set (0.00 sec)
其中还可以查询表的结构
desc table_name;
查询 user 表:
mysql> desc user;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(12) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
这就是查询到表结构:
filed 列名
Type 类型
Null 表示是否为空
Key 表示索引
Default 表示默认值
Extra 表示该表的额外信息等,常见的有 默认自增加等...
但是在创建表的时候,我们还有一些描述在里面,但是这样看不到描述。
show create table table_name;
上面就是查看创建时候的详细字段,但是上面这样查看并不好看,我们可以加一个 \G查看更好看。
mysql> show create table user \G
*************************** 1. row ***************************
Table: user
Create Table: CREATE TABLE `user` (
`id` int(11) DEFAULT NULL COMMENT '用户 ID',
`name` varchar(12) DEFAULT NULL COMMENT '用户名',
`birthday` date DEFAULT NULL COMMENT '用户生日'
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
这样查看就可以看到创建时候的详细信息了。
但是这和我们当时写的时候不一致,因为mysql 会记录用户的所有操作,但是也会在记录的时候帮这些内容进行修改,当然修改是更正式了。
表的删除也是很简单,和数据库删除一样,但是这里还是和数据库的删除一样,删除后就没办法恢复了,所以不建议随便删除。
drop table table_name;
删除表就不演示了。
修改表也是对表结构的一些修改,而不是修改其中的数据。
alter table table_name rename to table_name1;
上面是修改表名的语法
修改 user 为 user1:
mysql> alter table user rename to user1;
Query OK, 0 rows affected (0.00 sec)
下面开始正式介绍修改
添加一列:
alter table table_name add 列名 数据类型 [after 列明];
after 后面的列名 表示添加的一列在哪一列后面,如果不设置默认为最后
删除一列:
alter table table_name drop 列名;
修改一列数据类型:
alter table table_name modify 列名 新的数据类型;
修改列名:
alter table table_name change 列明 新列明 新数据类型;
示例:
user1 表中添加一列 path 到 birthday 后面 数据类型为 varchar(30)
mysql> alter table user1 add path varchar(30) after birthday;
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc user1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(12) | YES | | NULL | |
| birthday | date | YES | | NULL | |
| path | varchar(30) | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
删除 path 列
mysql> alter table user1 drop path;
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc user1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(12) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
将 name 列数据类型修改为 varchar(20)
mysql> alter table user1 modify name varchar(20);
Query OK, 0 rows affected (0.00 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc user1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(20) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
将 name 列的列名修改为 xingming 数据类型不变
mysql> alter table user1 change name xingming varchar(20);
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc user1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| xingming | varchar(20) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)