欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

PostgreSQL环境下,触发器的创建 postgreSQL触发器

程序员文章站 2022-05-08 21:10:38
...

前言:

有时候我们向数据库表中插入数据时,需要在插入前保证数据的约束。有两种方法可以保证约束不被破坏,1、插入前手动检查数据,2、使用触发器。今天我们就用触发器来保证约束完整性。

 

假设有如下两个关系

课程编号(course_name) 上课教室(room) 课程时间(time)
English BO-101 AM
History BO-102 AM
Physics BO-103 PM
Biology BO-104 PM

                                   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;

PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
 

teaches关系的数据:

SELECT id, course_name FROM teaches;

PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
 

插入一条有冲突的语句:

INSERT INTO teaches(id, course_name) VALUES('10003', 'Finance');

PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
 

大功告成。

 

附注:

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中是不行的,你只能这样

CREATE TRIGGER example_trigger1 BEFORE INSERT ON teaches
FOR EACH ROW
EXECUTE PROCEDURE example_function();

CREATE TRIGGER example_trigger2 BEFORE INSERT ON course
FOR EACH ROW
EXECUTE PROCEDURE example_function();

参见点击查看详情

 

结束语:以上的SQL语句全部是在PostgreSQL(9.4.4)中运行通过,由于各种数据库的语法的差别,在其他数据库中并不能保证不会报错。由于本人水平所限,如有错误,欢迎批评指正。

 

参考文献:

1. 《数据库系统概念》第六版 5.3节 触发器

2. http://www.postgresql.org/docs/current/static/plpgsql-trigger.html

3. http://www.postgresql.org/docs/9.4/static/sql-createtrigger.html

4. http://www.tutorialspoint.com/postgresql/postgresql_triggers.htm

5. http://*.com/questions/16102188/postgresql-insert-trigger-to-set-value

6. http://www.postgresql.org/message-id/17673.1129178350@sss.pgh.pa.us

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 9.2 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 9.1 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 17.6 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 20.1 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 10.7 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 13.4 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 25.2 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 10.1 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 14.9 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 14.2 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 5.6 KB
  • PostgreSQL环境下,触发器的创建
            
    
    
        postgreSQL触发器
  • 大小: 32.7 KB