MySQL(3)SQL语句的DDL详细入门

我们之前已经初步了解SQL语句的四大天王:DDL、DML、DQL、DCL的区别。今天我们来详细了解DDL。

目录

一、DDL:(Data Definition Language)

1、简介:数据定义语言,用来定义数据库对象(数据库,表, 字段)

2、数据库操作:

3、表操作


一、DDL:(Data Definition Language)

1、简介:数据定义语言,用来定义数据库对象(数据库,表, 字段)

2、数据库操作:

1)查询所有数据库 : show databases ;(记得加结束加分号)

2)查询当前数据库: select database( );

3)创建数据库: create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序 规则 ] ;

举个例子:

1、创建一个test数据库, 使用数据库默认的字符集: create database test;(好家伙习惯性忘记加分号了。)

我们会发现这样创建数据库虽然很便捷,但是它存在很多问题,比如:如果有重名的数据库呢?还有字符集问题,导致中文插入不了已及排序规则。

2、数据库去重创建:create database if not extists test;

3、创建一个cat数据库,并且指定字符集: create database cat default charset utf8mb4;

4、删除数据库: drop database [ if exists ] 数据库名 ;

如果删除一个不存在的数据库,将会报错。此时,可以加上参数 if exists ,如果数据库存在,再执行删除,否则不执行删除。

5、切换数据库: use 数据库名 ;

我们要操作某一个数据库下的表时,就需要通过该指令,切换到对应的数据库下,否则是不能操作的。 比如,切换到mydb1数据,执行如下SQL:

3、表操作

1、表操作-查询创建:

1)查询当前数据库所有表: show tables;

2)查看指定表结构: desc 表名 ;

通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为NULL,是否存在默认值等信息。

3)查询指定表的建表语句: show create table 表名 ;

通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询 到,因为这部分是数据库的默认值,如:存储引擎、字符集等。

4)创建表结构:

CREATE TABLE 表名(

字段1 字段1类型 [ COMMENT 字段1注释 ],

字段2 字段2类型 [COMMENT 字段2注释 ],

字段3 字段3类型 [COMMENT 字段3注释 ],

......

字段n 字段n类型 [COMMENT 字段n注释 ]

) [ COMMENT 表注释 ] ;

注意: [...] 内为可选参数,最后一个字段后面没有逗号

举个栗子:

create table tb_user(

id int comment '编号',

name varchar(50) comment '姓名',

age int comment '年龄',

gender varchar(1) comment '性别'

) comment '用户表';

2、表操作-数据类型

在上述的建表语句中,我们在指定字段的数据类型时,用到了int ,varchar,那么在MySQL中除了 以上的数据类型,还有哪些常见的数据类型呢? 接下来,我们就来详细介绍一下MySQL的数据类型。 MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。

1)数值类型:

比如:

1)年龄字段 -- 不会出现负数, 而且人的年龄不会太大 age tinyint unsigned

2)分数 -- 总分100分, 最多出现一位小数 score double(4,1)

2)字符串类型:

 

char 与 varchar 都可以描述字符串,char是定长字符串,指定长度多长,就占用多少个字符,和 字段值的长度无关 。而varchar是变长字符串,指定的长度为最大占用长度 。相对来说,char的性 能会更高些。

举个栗子:

1)用户名 username ------> 长度不定, 最长不会超过50 username varchar(50)

2)性别 gender ---------> 存储值, 不是男,就是女 gender char(1)

3)手机号 phone --------> 固定长度为11 phone char(11)

3) 日期时间类型:

 

举个栗子:

1)生日字段 birthday birthday date

2)创建时间 createtime createtime datetime

3、表操作-修改

1)添加字段: ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];

举个栗子:

为emp1表增加一个新的字段”昵称”为nickname,类型为varchar(20);

ALTER TABLE emp1 ADD nickname varchar(20) COMMENT '昵称';

 

这时候我们发现就多了一个nickname的字段;  

2)修改数据类型: ALTER TABLE 表名 MODIFY 字段名 新数据类型 (长度)

3)修改字段名和字段类型: ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];

案例: 将emp表的nickname字段修改为username,类型为varchar(30)

ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT '昵称';

修改好的界面:  

 

4) 删除字段: ALTER TABLE 表名 DROP 字段名;

 

删除成功界面:

 

5)修改表名: ALTER TABLE 表名 RENAME TO 新表名

案例: 将emp1表的表名修改为 employees

ALTER TABLE emp1 RENAME TO employees;

 

 修改成功界面:

4、表操作-修改

1)删除表:DROP TABLE [ IF EXISTS ] 表名;

可选项 IF EXISTS 代表,只有表名存在时才会删除该表,表名不存在,则不执行删除操作(如果不 加该参数项,删除一张不存在的表,执行将会报错)。

案例: 如果tb_user表存在,则删除tb_user表:DROP TABLE IF EXISTS tb_user;

2)删除指定表, 并重新创建表: TRUNCATE TABLE 表名;

注意: 在删除表的时候,表中的全部数据也都会被删除。

到这里我们大致了解了DDL的基础语法以及作用。还有用命令行打太难受了,下次还是用图形软件敲吧。

猜你喜欢

转载自blog.csdn.net/OMGcome/article/details/124230944