postgresql创建database, schema,用户以及权限分配

postgresql支持schema的概念,一个数据库下可以有多个schema,每个schema可以有多个表和其他数据库对象,然后每个schema可以分配给一个用户。这个时候,schema根oracle数据库的schema的概念比较像。

但是对于mysql,没有类似于oracle数据库schema的概念,postgresql又提供了一个public schema概念,默认建库之后,建表时如果不指定schema,默认都是建到这个默认public schema下。

postgresql就是通过这种方式保证了与oracle,mysql等传统数据库的兼容性。

在postgresql中创建一个用户之后,如果不做任何授权,默认新建用户是对该数据库服务器上所有的database和schema具有connectq权限的,链接之后,并且可以创建表等对象,但是对于别的用户在上边创建的对象没有读写权限。

所以为了安全考虑,在postgresql上创建数据库时,最好执行如下命令收回对除了数据库owner以外的所有public用户的针对该数据库的所有权限:

# revoke all on database db_name from public;

这里public代表所有用户,除了数据库owner.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值