mysql 数据库定义语言(DDL)

这篇具有很好参考价值的文章主要介绍了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 数据类型不变文章来源地址https://www.toymoban.com/news/detail-663095.html

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 数据库定义语言(DDL)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于mysql5.7制作自定义的docker镜像,适用于xxl-job依赖的数据库,自动执行初始化脚本(ddl语句和dml语句)

    xxl-job-admin依赖mysql数据库,且需执行初始化脚本,包括ddl和dml语句。 具体的步骤总结如下: 1、新建数据库xxl_job 2、创建mysql表table 3、执行dml语句,包括新建admin用户及密码,创建执行器和任务。 毫无疑问,人工每次去操作这些,不仅耗费人力和时间,还容易出错。 所以,本

    2024年02月11日
    浏览(164)
  • Oracle、达梦:☆获取数据库对象、获取对象的DDL定义语句(达梦)

    以下方式在达梦DM数据库中都能跑通,Oracle未测试所有的方式。 数据库所有对象表:包括 表、视图、物化视图、函数、存储过程……等 ①、ALL_OBJECTS视图方式 OBJECT_TYPE 解释: oracle 的ALL_OBJECTS中的OBJECT_TYPE表示: TABLE :表示表,这是用于存储和管理数据库中数据的主要结构。

    2024年02月03日
    浏览(83)
  • MySQL数据库——DDL基本操作

    DDL 操作是与数据库结构相关的操作,它们不涉及实际的数据操作,而是用于管理数据库的结构和元数据。今天我将为大家分享关于MySQL数据库的DDL操作。 SQL 功能 show databases; 查看所有的数据库 create database [if not exists] 数据库名 [charset/character=utf8]; 创建数据库 use 数据库名; 选

    2024年02月15日
    浏览(85)
  • MySQL数据库的DDL语法汇总

    DDL(数据定义语言):针对数据库对象结构的操作,如:数据库、表、视图、索引等 DML(数据操纵语言):对数据库对象中的数据进行操作,比如数据的增删改查 DCL(数据控制语言):授权及取消授权等 TCL(事务控制语言):对事务的控制,如事务的提交及回滚 创建数据库

    2024年02月09日
    浏览(56)
  • MySQL-DDL-数据库操作

    开发项目流程 DDL:Data Definition Language,数据定义语言,用来定义数据库对象(数据库、表) 常见操作 查询 查询所有数据库:show databases; 查询当前数据库:select database(); 使用 使用数据库:use 数据库名称; 创建 创建数据库:creste database[if not exists] 数据库名称; 删除

    2024年02月15日
    浏览(44)
  • 【MySQL 数据库】1、MySQL 的 DDL、DML、DQL 语句

    🎄 (1) MySQL 基础篇(初级工程师) ① MySQL 基础概念 ② SQL 语句 ③ 函数 ④ 约束 ⑤ 多表查询 ⑥ 事务 🎄 (2) MySQL 进阶篇(中级工程师) ① 存储引擎 ② 索引 ③ SQL 优化 ④ 视图、存储过程、触发器 ⑤ 锁 ⑥ InnoDB 核心 ⑦ MySQL 管理 🎄 (3) 运维篇(高级工程师) ① 日志 ② 主

    2024年02月05日
    浏览(47)
  • 【JaveWeb教程】(18) MySQL数据库开发之 MySQL数据库设计-DDL 如何查询、创建、使用、删除数据库数据表 详细代码示例讲解

    下面我们就正式的进入到SQL语句的学习,在学习之前先给大家介绍一下我们要开发一个项目,整个开发流程是什么样的,以及在流程当中哪些环节会涉及到数据库。 2.1 项目开发流程 需求文档: 在我们开发一个项目或者项目当中的某个模块之前,会先会拿到产品经理给我们提

    2024年01月25日
    浏览(104)
  • MySql数据库从0到1学习-第一天DDL学习

    数据库(查询/创建/修改/删除) 查询数据库 以下语句的database 可以替换为schema,效果一样 创建数据库 删除数据库 使用数据库 表(创建/删除/修改) 创建表 查询表 修改表 表字段约束 约束 描述 非空约束 限制该字段不可为null not null 唯一约束 保证该字段的所欲数据都是唯一

    2024年04月08日
    浏览(42)
  • 开源数据库Mysql_DBA运维实战 (DDL语句)

    例如:CREATE  DROP ALTER 定义库{                 创建业务数据库: CREAATE DATABASE   ___数据库名___ ;                 数据库名要求{                                         a.区分大小写                                         b.唯一性  

    2024年02月13日
    浏览(57)
  • MySQL数据库---库基本操作 以及 表结构的操作(DDL)

    目录 前言 一.数据库的操作 1.1显示当前数据库 1.2创建数据库 1.3使用数据库  1.4删除数据库  二.数据类型 2.1数值类型 2.2字符串类型 2.3日期类型 三.数据表的操作  3.1 创建表结构。  3.2查看数据库中拥有的数据表  3.3查看指定的表结构   3.4修改表结构   3.5删除表结构  

    2024年02月09日
    浏览(68)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包