postgresql的规则系统

Posted baisha

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了postgresql的规则系统相关的知识,希望对你有一定的参考价值。

" class="wiz-editor-body wiz-readonly" contenteditable="false">

Postgresql提供了一种规则系统。规则系统是查询重写规则的系统。从使用上说,规则系统的一些功能可以通过函数和触发器实现,但规则系统与触发器完全不同,它是在执行前把用户发过来的SQL通过内部的规则定义改变成另一个SQL后再执行的一种方式。

规则的基本语法如下:

CREATE RULE 规则名 AS

    ON {SELECT | INSERT | UPDATE | DELETE}

    TO 表名 [WHERE 规则条件]

    DO [INSTEAD] {NOTHING | 命令 | (命令, 命令...)}

PostgreSQL中,视图实际上是通过规则实现的,下面举例说明:

--创建视图v_test1

mydb=# create view v_test1 as select * from t1;

CREATE VIEW

--创建规则之前,先创建规则使用的表

mydb=# create table v_test2(id1 int);

CREATE TABLE

mydb=# create rule "_RETURN" as on select to v_test2 do instead select * from t1;

CREATE RULE

规则的名称必须写成"_RETURN",否则报如下错误

ERROR:  view rule for "v_test2" must be named "_RETURN"

创建后的结果如下所示,可以看到v_test1v_test2类型均为视图。

技术分享图片

以上是关于postgresql的规则系统的主要内容,如果未能解决你的问题,请参考以下文章

50.4. The PostgreSQL Rule System

PostgreSQL 规则有啥用?

PostgreSQL数据库之系统表学习总结

向 PostgreSQL 添加不区分大小写的排序规则

PostgreSQL——查询重写——定义规则

PostgreSQL——查询重写——定义规则