发布于 2016-04-21 00:20:08 | 176 次阅读 | 评论: 0 | 来源: 网友投递
这里有新鲜出炉的PostgreSQL指南,程序狗速度看过来!
PostgreSQL关系型数据库管理系统
PostgreSQL是以加州大学伯克利分校计算机系开发的 POSTGRES,现在已经更名为PostgreSQL,版本 4.2为基础的对象关系型数据库管理系统(ORDBMS)。
PostgreSQL 9.5 发布了,PostgreSQL 9.5 此次更新增加了许多新的功能,比如增加新的JSONB函数,新的GROUPING函数等。RLS(Row Level Security)功能在此次更新中也得到相应的提升。RLS是一种表格行安全机制,利用为每一个表加上你需要使用数据库角色作为一个主要的安全机制。
以下是一个RLS示例:
创建表、修改表、创建策略:使用RLS
CREATE TABLE ratings2 ( user_role_name NAME, rating_type_name TEXT, artist_name TEXT, rating INTEGER ); ALTER TABLE ratings2 ENABLE ROW LEVEL SECURITY; CREATE POLICY ratings2_user ON ratings2 USING(user_role_name = current_user);
上述封装了RLS最简单的例子。策略为每行返回一个布尔值。
这还可以通过声明每一种类型的声明以及它如何被授权的方式来定义。如果需要,选择和插入可以创建一个可读的附加表限于个人用户:
CREATE POLICY ratings2_user_select ON ratings2 FOR SELECT USING(user_role_name = current_user); CREATE POLICY ratings2_user_insert ON ratings2 FOR INSERT WITH CHECK(user_role_name = current_user);
或者,采用以下方式:
CREATE POLICY ratings2_user ON ratings2 USING(pg_has_role(current_user, user_role_name, 'member'));
用户组权限的改变,使用范围也随之改变。
CREATE ROLE group1; GRANT ALL ON ratings2 TO group1; CREATE ROLE music1 LOGIN PASSWORD 'change'; GRANT group1 to music1; CREATE ROLE music2 LOGIN PASSWORD 'change'; GRANT group1 TO music2;
更多完整发布信息,请看这里。