既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
course关系
教师编号(id) | 教授课程(course_name) |
10001 | History |
10002 | English |
10003 | Physics |
10001 | Biology |
teaches关系
现在要求实现约束“同一个教师不可能在同一时间在两个不同的教室上课”
这就要求我们每次向teaches关系中插入的数据,必须保证教师不会在同一时间,出现在两个不同的教室。转换成SQL语句就是
NOT EXISTS (
SELECT id
FROM teaches NATURAL JOIN course
GROUP BY id, time
HAVING COUNT(id) > 1);
创建触发器的SQL语句
CREATE TRIGGER example_trigger BEFORE INSERT ON teaches
FOR EACH ROW
EXECUTE PROCEDURE example_function();
example_function定义如下
CREATE FUNCTION example_function()
RETURNS TRIGGER
LANGUAGE plpgsql
AS $fun_trigger$
BEGIN
IF EXISTS (
SELECT id
FROM (SELECT id, course_name FROM teaches UNION (SELECT NEW.id, NEW.course_name)) AS T NATURAL JOIN course
GROUP BY id, time
HAVING COUNT(id) > 1)
THEN
RAISE EXCEPTION 'CONSTRAINT ERROR: A teacher cannot be in two classrooms at the same time';
END IF;
RETURN NEW;
END;
$fun_trigger$;
返回为TRIGGER(RETURNS TRIGGER)的存储过程中会自动创建一些变量
NEW:INSERT/UPDATE 操作新记录
OLD:DELETE/INSERT/UPDATE操作旧记录。更多的参数请参阅postgreSQL文档
course关系的数据:
SELECT course_name, room, time FROM course;
teaches关系的数据:
SELECT id, course_name FROM teaches;
插入一条有冲突的语句:
INSERT INTO teaches(id, course_name) VALUES('10003', 'Finance');
大功告成。
附注:
1.如果你需要在一个表(TABLE)更新(UPDATE)和插入(INSERT)时都触发触发器,SQL为
CREATE TRIGGER example_trigger BEFORE INSERT OR UPDATE ON teaches
FOR EACH ROW
EXECUTE PROCEDURE example_function();
2.如果你需要在一个表(TABLE)的指定列(COLUMN)更新时触发触发器,SQL为
CREATE TRIGGER example_trigger BEFORE UPDATE OF course_name ON teaches
FOR EACH ROW
EXECUTE PROCEDURE example_function();
3.如果你想用一个触发器(TRIGGER)作用在多个表上(TABLE),该怎么办呢?
CREATE TRIGGER example_trigger BEFORE INSERT ON teaches, course
FOR EACH ROW
EXECUTE PROCEDURE example_function();
不幸的是,这样的语法在postgreSQL中是不行的,你只能这样
![img](https://img-blog.csdnimg.cn/img_convert/fef16ff5dc825380826ca402123ddcab.png)
![img](https://img-blog.csdnimg.cn/img_convert/4b8ea9b7fd657eeb0669992723fc0ace.png)
![img](https://img-blog.csdnimg.cn/img_convert/6392e568e4f95919c943bf7722927c4e.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**
的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**