AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题 / 33943
Accepted
PlaidFan
PlaidFan
Asked: 2013-02-01 19:27:09 +0800 CST2013-02-01 19:27:09 +0800 CST 2013-02-01 19:27:09 +0800 CST

授予用户对所有表的访问权限

  • 772

我是 Postgres 的新手,正在尝试迁移我们的 MySQL 数据库。在 MySQL 中,我可以授予低权限用户的SELECT、UPDATE、INSERT和DELETE权限,并使这些授予适用于指定数据库中的所有表。我必须在 Postgres 中遗漏一些东西,因为看起来我必须一次为每个表授予这些权限。有许多数据库和每个数据库数百个表,这似乎是一项艰巨的任务,只是为了起步。此外,一旦数据库开始运行,添加表的频率就会很高,除非绝对必要,否则我不希望每次都授予权限。

这如何最好地完成?

postgresql best-practices
  • 5 5 个回答
  • 501757 Views

5 个回答

  • Voted
  1. Best Answer
    dezso
    2013-02-02T04:36:08+08:002013-02-02T04:36:08+08:00

    首先,您必须能够连接到数据库才能运行查询。这可以通过

    REVOKE CONNECT ON DATABASE your_database FROM PUBLIC;
    
    GRANT CONNECT
    ON DATABASE database_name 
    TO user_name;
    

    REVOKE是必要的,因为

    关键字 PUBLIC 表示权限将授予所有角色,包括以后可能创建的角色。PUBLIC 可以被认为是一个隐含定义的组,它始终包含所有角色。任何特定角色都将拥有直接授予它的权限、授予其当前成员的任何角色的权限以及授予 PUBLIC 的权限的总和。

    如果您真的想将您的用户限制为 DML 语句,那么您还有更多工作要做:

    REVOKE ALL
    ON ALL TABLES IN SCHEMA public 
    FROM PUBLIC;
    
    GRANT SELECT, INSERT, UPDATE, DELETE
    ON ALL TABLES IN SCHEMA public 
    TO user_name;
    

    这些假设您将只有一个模式(默认情况下名为“公共”)。

    正如 Jack Douglas 指出的那样,上面的内容只为已经存在的表提供了权限。要为将来的表实现相同的功能,您必须定义默认权限:

    ALTER DEFAULT PRIVILEGES 
        FOR ROLE some_role   -- Alternatively "FOR USER"
        IN SCHEMA public
        GRANT SELECT, INSERT, UPDATE, DELETE ON TABLES TO user_name;
    

    在这里,some_role是创建表的角色,而user_name获得特权的角色。定义这一点,您必须以它的身份some_role或成员身份登录。

    最后,你必须对序列做同样的事情(感谢 PlaidFan 指出)——这就是USAGE你需要的特权。

    • 215
  2. alxkls
    2013-02-02T03:52:11+08:002013-02-02T03:52:11+08:00

    假设你想给他们所有的特权 - 这样做:

    grant all privileges on database dbname to dbuser;
    

    wheredbname是您的数据库dbuser的名称,是用户的名称。

    • 60
  3. Ganbayar Gansukh
    2017-10-07T14:10:34+08:002017-10-07T14:10:34+08:00

    授予数据库中所有表的所有权限是通过以下方式实现的

    GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA <schema_name> TO <username>;
    GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA <schema_name> TO <username>;
    
    • 38
  4. Will
    2014-08-22T09:26:31+08:002014-08-22T09:26:31+08:00

    可能是我在这里做错了什么,因为我对 PostgreSQL 很陌生。但这只是为我解决了问题的第一部分——在所有现有表上设置权限。

    为了在创建的新表上为我的用户正确设置权限,我必须为用户设置默认权限:

    ALTER DEFAULT PRIVILEGES IN SCHEMA public
      GRANT SELECT, INSERT, UPDATE, DELETE ON tables TO user_name;
    
    ALTER DEFAULT PRIVILEGES IN SCHEMA public
      GRANT SELECT, USAGE ON sequences TO user_name;
    
    • 22
  5. Jorge Valenzuela
    2018-04-04T04:25:53+08:002018-04-04T04:25:53+08:00
    --Create User
    
    CREATE USER my_user_test WITH LOGIN NOSUPERUSER NOCREATEDB  NOCREATEROLE    INHERIT NOREPLICATION   CONNECTION LIMIT -1 PASSWORD 'xxxxxxx';
    
    -- Grant connect to my data base
    
    GRANT CONNECT ON DATABASE my_db_test TO my_user_test;
    
    -- Grant usage the schema
    
    GRANT USAGE ON SCHEMA my_sch_test TO my_user_test ;
    
    -- Grant all table for SELECT, INSERT, UPDATE, DELETE
    
    GRANT SELECT, INSERT, UPDATE, DELETE ON ALL TABLES IN SCHEMA my_sch_test TO my_user_test;
    
    • 7

相关问题

  • 运行时间偏移延迟复制的最佳实践

  • 连接不同地理区域的数据库的最佳实践

  • 存储过程可以防止 SQL 注入吗?

  • PostgreSQL 中 UniProt 的生物序列

  • PostgreSQL 9.0 Replication 和 Slony-I 有什么区别?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    授予用户对所有表的访问权限

    • 5 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    pedrosanta 使用 psql 列出数据库权限 2011-08-04 11:01:21 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve