五大约束

约束:

约束是添加在表中的某个/某些字段上,使得字段的值必须遵循某一些特定的约束.

主键约束

关键字  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 $$   ,设置结束符为$$

存储过程的缺点:

可移植性差,现在几乎不使用存储过程