五、DDL语言
简介
DDL:数据定义语言,库和表的管理
库的管理:
- 创建
- 修改
- 删除
表的管理:
- 创建
- 修改
- 删除
命令:
- 创建:create
- 修改:alter
- 删除:drop
库的管理
创建
语法
普通:create datebase 库名
提高容错性:create datebase if not exists 库名
修改(一旦创建库,一般不修改)
语法
重命名:rename database 库名 to 新库名; (已经废弃)
修改字符集:alter database 库名 character set 字符集;
删除
语法
删除库:
- drop database 库名;(不安全)
- drop database if exists 库名;(安全)
表的管理
创建
语法
create table is not exists 表名(
列名 列的数据类型【(类型长度) 约束】,
列名 列的数据类型【(类型长度) 约束】,
......
列名 列的数据类型【(类型长度) 约束】
);
修改
修改列名
alter table 表名 change column 旧列名 新列名 数据类型;
列的类型或约束
修改某一列的数据类型:
alter table 表名 modify column 列名 新数据类型;
添加列
alter table 表名 add column 新列名 数据类型;
alter table 表名 add column 新列名 数据类型 【first|after 字段名】; 调整字段顺序
删除列
alter table 表名 drop column 列名;
修改表名
alter table 表名 rename to 新表名;
删除
语法
drop table if exists 表名;
复制
仅复制表结构
语法
create table 新表 like 已存在的表;
复制表结构+数据
语法
create table 新表 select * from 旧表;
复制表结构+部分数据
语法
create table 新表 select * from 旧表 where 筛选条件;
常见约束
含义
一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性
分类
六大约束
- not null(该字段不能为空约束)
- default(默认,用于保证该字段有默认值)
- primary key(主键,用户保证该字段值具有唯一性,非空字段)
- unique(唯一,用于保证该字段的值具有唯一性,可为空)
- check(检查约束,【Mysql不支持,语法不报错,但无效果】)
- poreign key(外键约束,用于限制两个表的关系,该字段值必须来自主表关联字段的值,在从表添加外键约束,用于引用主表中某列的值)
添加分类
- 列级分类
- 六大约束语法上都支持,但外键约束没效果
- 表级分类
- 除了非空约束(not null)和默认约束(default),其它都支持
创建表时添加约束
添加列级约束
语法:
直接在字段名和类型后面追加 约束类型 即可。
支持的约束:默认(default)、非空(not null)、主键(primary key)、唯一(unique)
示例:
create database students; # 创建数据库
use students; # 进入数据库
# 学生表
create table stu_info(
id int(11) primary key, # 主键约束
stu_name varchar(20) not null, # 非空约束
sex char(1) check(sex ='男' or sex='女'), # 检查约束,Mysql不生效,仅作演示
seat int(11) unique, # 唯一约束
age int(3) default 18, # 默认约束,默认18岁
# major_id int(11) foreign key references major(id) # 外键约束
major_id int(11) references major(id) # 外键约束
);
# 专业表
create table major(
id int(11) primary key, # 主键约束
major_name varchar(50)
);
查看 学生表 信息:
查看 学生表 所有索引:
可以看到,外键约束并没有起作用。
添加表级约束
语法:
- 在各个字段最下面
- constraint 约束名 约束类型(字段名)
- constraint关键字就是为添加的约束起个别名不写也行,
- 注意:主键约束别名为primary,改了也不生效
示例:
create database students; # 创建数据库
use students; # 进入数据库
# 学生表
create table stu_info(
id int(11) ,
stu_name varchar(20),
sex char(1) ,
seat int(11),
age int(3),
major_id int(11),
constraint pk primary key(id), #主键
constraint uq unique(seat), #唯一
constraint ck check(sex='男' or sex='女'), #检查约束
constraint fk_major foreign key(major_id) references major(id) #外键
);
# 专业表
create table major(
id int(11) primary key, # 主键约束
major_name varchar(50)
);
查看 学生表 信息:
查看 学生表 所有索引:
可以看到,表级约束中外键约束起到了作用。
列、表级约束一起写
语法:
create database students; # 创建数据库
use students; # 进入数据库
# 学生表
create table stu_info(
id int(11) primary key, # 主键约束
stu_name varchar(20) not null, # 非空约束
sex char(1) check(sex ='男' or sex='女'), # 检查约束,Mysql不生效,仅作演示
seat int(11) unique, # 唯一约束
age int(3) default 18, # 默认约束,默认18岁
major_id int(11),
constraint fk_major foreign key(major_id) references major(id) #外键
);
# 专业表
create table major(
id int(11) primary key, # 主键约束
major_name varchar(50)
);
主键约束和唯一约束对比
保证唯一性 | 是否允许为空 | 表中是否可有多个 | 是否允许组合 | |
---|---|---|---|---|
主键约束 | √ | × | 主键只能有一个;但是可创建多个列联合主键 | 两个列组合成一个主键:允许 |
唯一约束 | √ | √ | 可以有多个 | 两个列组合成一个唯一:允许 |
多个列联合主键示例
create table stu_info(
id int(11) ,
stu_name varchar(20) not null, # 非空约束
sex char(1) check(sex ='男' or sex='女'), # 检查约束,Mysql不生效,仅作演示
seat int(11) unique, # 唯一约束
age int(3) default 18, # 默认约束 默认18岁
primary key(`id`,`stu_name`) # id和stu_name组合成主键
);
# 成功添加:
truncate table stu_info;
insert into stu_info value(1, '张三', '男', 12, 18);
insert into stu_info value(2, '张三', '男', 13, 19);
# 成功添加:
truncate table stu_info;
insert into stu_info value(1, '张三', '男', 12, 18);
insert into stu_info value(1, '李四', '男', 13, 19);
# 失败添加:
truncate table stu_info;
insert into stu_info value(1, '张三', '男', 12, 18);
insert into stu_info value(1, '张三', '男', 13, 19);
外键
特点
- 在从表上设置外键关系
- 从表的外键列的类型和主表的关联列的类型要求一致或兼容
- 主表中关联列必须是一个key(一般是主键、唯一键)
- 插入数据要先插入主表再插入从表
- 删除数据先删除从表再删除主表
修改表时添加约束
示例
# 修改非空约束
alter table 表 modify column字段 varchar(20) not null;
# 默认约束,默认值:'demo'
alter table 表 modify column字段 varchar(20) default 'demo';
# 添加主键
alter table 表 modify column 字段 int(11) primary key;
alter table 表 add primary key(字段) ;
# 添加唯一键
①列级约束
alter table 表 modify column 字段 int(11) unique;
②表级约束
alter table 表 add unique(字段);
# 添加外键
alter table 表 add foreign key(字段) references 【外键的作用】;
修改表时删除约束
示例
# 删除非空约束
alter table 表 modify column字段 varchar(20) null;
# 删除主键
alter table 表 drop primary key;
# 删除唯一约束
alter table 表 drop index;
标识列(自增长列)
含义
可以不用手动插入值,系统提供默认序列值
特点
- 标识列必须和主键搭配吗?不一定,但要求必须是一个key
- 一个表可有多个标识列吗?至多一个
- 标识列类型只能是数值型,如 int、float、double
举例
create table demo(
id int primary key auto_increment, # id为主键并设为自增
name varchar(10)
)
# 插入五条数据
insert into demo values(null, 'AAA'),(null, 'BBB'),(null, 'CCC'),(null, 'DDD');
# 查看
select * from demo;
+----+------+
| id | name |
+----+------+
| 1 | AAA |
| 2 | BBB |
| 3 | CCC |
| 4 | DDD |
+----+------+
五、DDL语言的更多相关文章
- Android For JNI(五)——C语言多级指针,结构体,联合体,枚举,自定义类型
Android For JNI(五)--C语言多级指针,结构体,联合体,枚举,自定义类型 我们的C已经渐渐的步入正轨了,基础过去之后,就是我们的NDK和JNI实战了 一.多级指针 指针的概念我们在前面 ...
- 【转】ORACLE SQL基础—DDL语言 礼记八目 2017-12-23 21:26:21
原文地址:https://www.toutiao.com/i6502733303550837261/ SQL语言分为:DDL数据定义语言,DML数据操纵语言,DCL是数据库控制语言,TC事务控制语言 ...
- MySQL笔记总结-DDL语言
DDL语言 数据类型 一.数值型 1.整型 tinyint.smallint.mediumint.int/integer.bigint 1 2 3 4 8 特点: ①都可以设置无符号和有符号,默认有符 ...
- 手把手和你一起实现一个Web框架实战——EzWeb框架(五)[Go语言笔记]Go项目实战
手把手和你一起实现一个Web框架实战--EzWeb框架(五)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 本篇代码,请选择demo5 中间件实现 ...
- DDL 语言
数据库模式定义语言并非程序设计语言,DDL数据库模式定义语言是SQL语言(结构化查询语言)的组成部分. SQL语言包括四种主要程序设计语言类别的语句:数据定义语言(DDL),数据操作语言(DML),数 ...
- (五)c语言条件编译#ifdef与#if defined
c语言条件编译#ifdef与#if defined defined NAME是用来判断NAME是否被定义了(被用define定义了). #ifdef NAME == #if defined(NAME) ...
- Oracle-04:DDL语言数据表的操作
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- DDL操作: --创建学生表 create table student( sno number(4) not ...
- MySql DDL语言(数据库和数据表的管理)
数据定义语言,负责数据库和数据表的管理 ⒈数据库的管理 1.创建数据库 create database if not exists DatabaseName; #if not exists可以省略 2 ...
- 快用Visual Studio(五)- 语言特性
HTML 自带Emment $ SHIFT + OPTION + F:格式化代码 其他语言特性提示 CSS & LESS hover属性,提示样式对象标签 $ CMD + SHIFT + O: ...
随机推荐
- jpa基于按annotation的hibernate主键生成策略
JPA注解持久化类很方便,需要jar包:ejb3-persistence.jar下载 一.JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hib ...
- Druid Monitor监控Java Web和Java SE项目
Druid Monitor 对于数据源,大家已经接触了不少了.比如c3p0.dhcp.proxool等,之后又发现使用tomcat-jdbc可以大大的提高性能.但是针对于我们的高并发的系统来说,总希望 ...
- haproxy报错解决
.有一次访问出现 错误 http://192.168.0.200:10080 haproxy service unavailable no server is avaible to handle th ...
- webdriervAPI(控制浏览器及简单元素操作)
from selenium import webdriver driver = webdriver.Chorme() driver.get("http://www.baidu.co ...
- Ubuntu中 apt-get -f install 命令
Ubuntu 下当发现可能是安装的其他软件包不兼容导致了安装包出错时,可以根据提示需要执行“sudo apt-get -f install ”来卸载之前的冲突包. 如果安装过aptitude包,还可 ...
- 最新 三七互娱java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.三七互娱等10家互联网公司的校招Offer,因为某些自身原因最终选择了三七互娱.6.7月主要是做系统复习.项目复盘.Leet ...
- 通过js获取本机的IP地址
参考链接:https://blog.csdn.net/qq_39327418/article/details/90052668
- 修改ssh登录的初始目录
目录 修改ssh登录的初始目录 title: 修改ssh登录的初始目录 date: 2019/11/27 20:18:27 toc: true --- 修改ssh登录的初始目录 /etc/passwd ...
- IO阻塞模型、IO非阻塞模型、多路复用IO模型
IO操作主要包括两类: 本地IO 网络IO 本地IO:本地IO是指本地的文件读取等操作,本地IO的优化主要是在操作系统中进行,我们对于本地IO的优化作用十分有限 网络IO:网络IO指的是在进行网络操作 ...
- 数据库连接池——C3P0&Druid(快速入门)
数据库连接池--C3P0&Druid (一) 数据库连接池 每一个事物都有其存在的意义,在初学jdbc的时候,我们建立数据库连接对象后,会对其进行释放,但是数据库连接的建立和关闭是非常消耗资源 ...