Mysql之约束与事件

前言

讲一下mysql剩余的,这是以前的写的博客,忘记发了

1. 约束

1.1 普通约束

MySQL不支持检查约束

sql 复制代码
#员工表
create table emp(
    id int,#员工id,主键且自增长
    name varchar(50),#非空且唯一
    join_date date,#入职日期,,非空
    salary double(7,2),#非空
    bonus double(7,2)#奖金,如果没有默认为0
);

添加约束为

sql 复制代码
#员工表
create table emp(
    id int primary key ,#员工id,主键且自增长 
    name varchar(50) not null unique ,#非空且唯一
    join_date date not null,#入职日期,,非空
    salary double(7,2) not null ,#非空
    bonus double(7,2) default 0#奖金,如果没有默认为0
);

这个没有写自增长

sql 复制代码
#验证非空
insert into emp values(1,'张三','1999-11-11',8800,5000);
insert into emp values(1,null,'1999-11-11',8800,5000);
sql 复制代码
insert into emp values(1,'张三','1999-11-11',8800,5000);

这个是唯一

非空就是不能为null,,唯一就是不能相同

没有默认为0的意思是你不写为0,你写null还是null

违反的话就会报错

sql 复制代码
#员工表
create table emp(
    id int primary key auto_increment,#员工id,主键且自增长
    name varchar(50) not null unique ,#非空且唯一
    join_date date not null,#入职日期,,非空
    salary double(7,2) not null ,#非空
    bonus double(7,2) default 0#奖金,如果没有默认为0
);

这样就有自增长了

自增长的意思就是你不写编号的时候,或者你写编号为null的时候,会给编号默认增大的值,而且是会自动排序的

1.2 外键约束

外键约束就是对两个表建立联系

sql 复制代码
alter table emp1 add constraint fk_dep_id foreign key (dep_id) references emp2(id);

这个就是添加外键

修改emp1 ,给emp1 添加外键,add constraint fk_dep_id添加外键为fk_dep_id,把emp1 的dep_id关联到emp2的id

但这样我不能运行,是因为id没有索引,会报错

Failed to add the foreign key constraint. Missing index for constraint 'fk_emp3_dep_id' in the referenced table 'emp2'

sql 复制代码
 ALTER TABLE emp2 ADD INDEX (id);

给id添加一个索引就可以了

这样就可以建立一个dep_id到id的约束了

同时选中两个表,右键选图就可以看到了

sql 复制代码
ALTER TABLE emp3 DROP FOREIGN KEY fk_emp3_dep_id;

这个就是删除约束

就是删除两个表之间的联系

以前有约束的时候,两个表之间有联系

dep_id的每个值在id中都能找到

意思就是id就是dep_id的所有类型,dep_id的每个值都会在id中找到

意思就是dep_id有很多个1,但是id只有一个1,而且dep_id所有的1都指向id的那个1,如果要删除id的1,还要删除dep_id的所有1才行,要删除,emp3,还要删除emp2所有数据

数据库设计








多表查询










内连接






外连接




子查询







多行单列:did就是多行单列的,用in



多行多列


事务


把他们全部当做事务来对待,这样就不会出现这种问题了,500块不易而发,因为可以一起失败

开启事务开始执行,后面的语句只是虚拟执行,并没有完全执行,异常的话,就回滚,回到开启事务,原来执行的都不算,到了提交事务的话,原来执行的才算





这里全部执行,就报错了,只执行了-500


报错那里执行的操作都是临时性的操作,只有自己这个用户才能看到错误,其他用户是看不到的

这里在回滚一下

数据就会恢复到以前

当然其他用户来查,还是一样不变的

只有提交了事务,才是永久性的操作


这样提交数字为1,就是默认提交的

事务执行成功就是默认提交的

相当于后面自己写了一个commit

commit设置为0,就是手动提交的

意思是我们设置为0之后,要提交的话,必须是手动写一个commit来提交

总结

相关推荐
QING61815 分钟前
Kotlin groupBy用法及代码示例
android·kotlin·源码阅读
QING61817 分钟前
Kotlin getOrElse用法及代码示例
android·kotlin·源码阅读
明明明h17 分钟前
MySQL 查看本地用户名和密码
数据库·mysql·adb
QING61820 分钟前
Kotlin getOrNull用法及代码示例
android·kotlin·源码阅读
QING61820 分钟前
Kotlin getValue用法及代码示例
android·kotlin·源码阅读
QING61822 分钟前
Kotlin getOrPut用法及代码示例
android·kotlin·源码阅读
QING61822 分钟前
Kotlin groupingBy用法及代码示例
android·kotlin·源码阅读
祖师爷科技25 分钟前
kotlin扩展函数的实现原理
android·kotlin
QING61828 分钟前
Kotlin contentToString用法及代码示例
android·kotlin·源码阅读
QING61828 分钟前
Kotlin associateBy用法及代码示例
android·kotlin·源码阅读