五大约束
约束:
约束是添加在表中的某个/某些字段上,使得字段的值必须遵循某一些特定的约束.
主键约束
关键字 primary key
特点:元素唯一且非空
eg:
create table t_name(
id int primary key,
....
....)
外键约束
外键:A表中的非主键字段引用自另一个表中的主键字段,则该字段称为外键
关键字: foreign key
特点:若某个主键值作为外键使用,则外键中使用该主键值的期间,
该主键值无法删除(除非将外键值中的引用全部删除)
给某个字段添加外键
create table t_name(
id int primary key,
name varchar(20),
dept_id int,
foreign key(dept_id) references dept(id) )
唯一性约束
关键字: unique
特点:字段的值唯一存在,不可重复
create table t_name(id int primary key,
name varchar(20) unique,
age int)
非空约束
关键字: not null
特点:字段的值不允许为null
添加方式:
create table t_name(id int primary key,
name varchar(20) unique,
age int not null);
检查约束
作用:添加给某字段,向该字段添加值时,会检查添加的值是否满足检查约束给出的条件
关键字:check
用法:
create table t_name(
id int,
name varchar(20),
age int check(age between 12 and 20))
注意点:mysql不支持检查约束,sql server,Oracle,Mariadb10.xx均支持
between...and....:两个边界值均包含的
储存过程
什么是储存过程
关键字: procedure
用于封装一段过程,封装之后,后续若要再次调用该过程,调用名称即可.
eg:某操作需要以下的sql语句才能完成
select....
delete....
update....
insert....
select....
select....
若后期其他地方也要执行该操作,若将以上的所有sql语句重写一遍可以实现效果,
但是若后期是多次执行以上操作,多次重写以上sql.此时编写代码的效率是相当低下的,
我们应该讲该过程进行提取,此时就可以使用存储过程来封装该过程,
后期若想再次执行该过程,直接调用存储过程名即可.
- 存储过程相当于Java中的方法
创建存储过程
create procedure name(xx,xx,xx)
begin
select...;
delete...;
update...;
.....
end$$
调用存储过程: call name(....)
修改结束符:
存储过程结束符默认是;,但是每条sql语句后也是;此时会产生问题
结束符需要进行修改
设置结束符方式:
delimiter $$ ,设置结束符为$$
存储过程的缺点:
可移植性差,现在几乎不使用存储过程