mysql 数据库定义语言(DDL)

目录

库的操作

数据库创建

数据库编码集

数据库删除

数据库修改

数据库查询

数据库备份

表的操作

表的创建

查询表

删除表

修改表


库的操作

这里先声明一下,这篇文章主要是讲数据库表的定义操作,也就是 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)

你可能感兴趣的:(mysql,数据库,mysql,adb)