MySQL基础(六)之DDL

数据定义语言

库和表的管理
一、库的管理
创建、修改、删除
二、表的管理
创建、修改、删除

创建:creat
修改:alter
删除:drop

一、库的管理

1、库的创建
语法:
create database [ if exists ] 库名;

2、库的修改
一般不允许修改库

3、库的删除
drop database 【if exists 】 库名;

二、表的管理

1、表的创建
create table 【if exists 】表名(
列1, 列1 的类型【(长度) 约束】,
列2, 列2 的类型【(长度) 约束】,
。。。。。

在这里插入图片描述
2、表的修改
语法:
alter table 表名 add/drop/modify/change column 列名 【 列类型 约束】

1)、修改列名
ALTER TABLE book CHANGE COLUMN publishdate(旧列名) puDate(新列名) DATETIME(新类型);
2)、修改列的类型或约束
ALTER TABLE book MODIFY COLUMN publishdate(列名) DATETIME(新类型);
3)、添加新列
ALTER TABLE author ADD COLUMN annual DOUBLE 【first / after 字段名 (添加到指定位置)】;
4)、删除列
ALTER TABLE author DROP COLUMN annual ;
5)、修改表名
ALTER TABLE author RENAME TO book_author;

3、表的删除
DROP TABLE IF EXISTS 表名;

4、表的复制

1、仅仅复制表的结构
CREATE TABLE copyse LIKE book_author;

2、复制表的结构和数据
CREATE TABLE copyse1
SLECT * FROM author;

只复制部分数据
CREATE TABLE copyse1
SLECT id,au_name
FROM author
WHERE nation=“中国”;

常见数据类型

1、数值型:
	1)、整型
	2)、小数:定点数,浮点型
2、字符型:
1)、较短的文本:char、varchar
2)、较长的文本:text、blob(较长的二进制数据)
3、日期型:

一、整型

在这里插入图片描述
特点:
1、如果不设置无符号还是有符号,默认是有符号,如果想设置无符号,需要添加unsigned关键字
2、如果插入的数值超出了整型的范围,会报out of range异常,并且插入临界值
3、如果不设置长度,会有默认的长度
长度代表了显示的最大宽度,如果不够会用0在左边填充,但必须搭配zerofill使用,并且默认变为无符号整型!

二、小数

在这里插入图片描述

分类:
1、浮点型
float(M,D)
double(M,D)
2、定点型
dec(M,D)
decimal(M,D)
特点:
1、(M,D)
M 代表整数部位+小数部位
D 小数部位
如果超过范围,则插入临界值
2、M 和D都可以省略
如果是decimal,则M默认为10,D默认为0
如果是float和double,则会根据插入的数值的精度来决定精度
3、定点型的精度较高,如果要求插入数值的精度较高如货币运算等则考虑使用定点型

原则:所选择的类型越简单越好,能保存数值的类型越小越好

三、字符型

在这里插入图片描述
1)、较短的文本:char、varchar
写法:char(M) varchar(M)

名字写法M的意思特点空间的耗费情况效率
charchar(M)最大的字符数,可以省略,默认为1固定长度的字符比较耗费
varcharvarchar(M)最大的字符数,不可省略可变长度的字符比较节省

特点:

2)、较长的文本:text、blob(较长的二进制数据)

四、日期型

在这里插入图片描述
datetime和timestamp的区别
在这里插入图片描述
总结:
分类:
date只保存日期
time只保存时间
year只保存年

datetime保存日期和时间
timestamp保存日期和时间
特点:

类型字节范围时区等的影响
datetime81000-9999不受
timestamp41970-2038

常见约束

含义:一种限制,用于限制表中的数据,为了保证表中的数据的准确性和可靠性

分类:六大约束
NOT NULL:非空,用于保证该字段的值不能为空,如姓名,学号等
DEFAULT:默认约束,用于保证该字段有默认值,比如性别等
PRIMARY KEY:主键,用于保证该字段的值具有唯一性,且非空,比如学号等
UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空,比如座位号
CHECK:检查约束【mysql 中不支持】
FOREIGN KEY:外键,用于限制两个表的关系,用于保证该表字段的值必须来自于主表的关联列的值(在从表添加外键约束,用于引用主表中某列的值,比如学生表的专业编号,员工表的部门编号,员工表的工种编号)

添加约束的时机:
1、创建表时
2、修改表时

约束的添加分类:
1、列级约束:六大约束语法上都支持,但外键约束没有效果
2、表级约束:除了非空、默认,其他的都支持

一、创建表时添加约束

1、添加列级约束
语法:
直接在字段名和类型后面追加约束类型即可。
支持:默认、非空、主键、唯一

2、添加表级约束
语法:在各个字段的最下面
【constraint 约束名】约束类型(字段名)

通用的写法:

create table if not exists stuinfo(
		id int primary key ,
		stuName varchar(20) NOT NULL,
		sex char(1),
		age int default 18,
		seat int unique,
		majorid int,
		constraint fk_stuinfo_major foreign key(majorid) references major(id)

主键和唯一的对比:

类型保证唯一性是否允许为空一个表中可以有多少个是否允许组合
主键不能至多有1个允许,但不推荐
唯一可以多个允许,但不推荐

外键:
1、要求在从表设置外键关系
2、从表的外键列的类型和主表的关联列的类型要求一致或兼容,名称无要求
3、主表的关联列必须是一个key(一般是主键或唯一)
4、插入数据时,先插入主表,在插入从表。删除数据时,先删除从表,在删除主表。

可以通过以下两种方式来删除主表的记录

方式一、级联删除

alter table stuinfo add constraint fk_stu_majoy foreign key(majorid) references major(id) on delete cascade;

方式二、级联直空

alter table stuinfo add constraint fk_stu_majoy foreign key(majorid) references major(id) on delete set Null;
列级约束和表级约束比较:
列别位置支持的约束类型是否可以起约束名
列级约束列的后面语法都支持,但外键没有效果不可以
表级约束所有列的下面默认和非空不支持,其他都支持可以(主键没有效果)

二、修改表时添加约束

1、添加列级约束
alter table 表名 modify column 字段名 字段类型 新约束;
2、添加表级约束
alter table 表名 add 【constraint 约束名】约束类型(字段名)【外键的引用】;

修改表示删除约束

一、创建表时设置标识列

在这里插入图片描述

标识列:

标识列又称为自增长列
含义:可以不用手动的插入值,系统提供默认的序列值

特点:
1、 标识列必须和主键搭配吗?不一定,但要求是一个key
2、一个表可以有几个标识列?至多一个
3、标识列的类型只能是数值型
4、标识列可以通过 SET auto_increment_increment = 3;设置步长,也可以手动插入值,设置起始值

二、修改表时设置标识列
在这里插入图片描述
三、修改表时删除标识列
![!](https://img-blog.csdnimg.cn/20200109150400512.png)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值