首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgreSQL和GRANT语句

PostgreSQL和GRANT语句
EN

Stack Overflow用户
提问于 2013-02-08 22:19:54
回答 2查看 103关注 0票数 2

我的PostgreSQL服务器(V9.2)上有n个模式和n个用户(每个模式1个用户)。我只想在每个表上将权限SELECT, INSERT, UPDATE, DELETE, EXECUTEuser1分配给schema1,将user2分配给schema2,将usern分配给scheman

我不能用下面的语句做到这一点:

代码语言:javascript
复制
GRANT SELECT, INSERT, UPDATE, DELETE, EXECUTE ON SCHEMA schema 1 to user1

因为子句...ON SCHEMA只适用于CREATEUSAGE特权。

那么,将每个表上的所有这些权限分配给相关用户的最快方法是什么?我希望唯一的方法是不为每个schema.table执行一条GRANT语句...?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-02-08 22:31:27

我认为您正在寻找"ON ALL TABLES IN SCHEMA“选项:

代码语言:javascript
复制
GRANT SELECT, INSERT, UPDATE, DELETE, EXECUTE ON ALL TABLES IN SCHEMA schema_1 to user1;

有关更多细节,请参阅手册:http://www.postgresql.org/docs/current/static/sql-grant.html

票数 3
EN

Stack Overflow用户

发布于 2013-02-08 22:26:43

虽然对于这个问题有很多不同的解决方案(包括手动修改授权表),但我个人建议使用一个工具来使其更容易。

例如,使用pgAdmin3,您只需批量更改模式中所有对象的权限。

http://www.pgadmin.org/docs/1.4/grantwiz.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14774576

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档