PostgreSQL的基础操作
在psql命令行(客户端)下,执行了一次\l,查看所有的库信息
可以直接基于psql查看一些信息,也可以基于psql进入到命令行后,再做具体操作
可以直接基于psql操作。
1 | 可以使用psql --help,查看psql的命令 |
后面都基于psql的命令行(客户端)去进行操作
命令不用背,需要使用的时候,直接找帮助文档,在psql命令行中,直接输入如下命令:
1 | \help,即可查看到数据库级别的一些命令 |
用户相关
构建用户命令:
1 | # create user默认有连接权限,而create role没有,但可以基于选项设置 |
创建一个超级管理员用户:
1 | CREATE USER root WITH SUPERUSER PASSWORD 'root'; |
退出psql命令行
尝试去用root用户登录的psql命令:
1 | psql -h 192.168.11.32 -p 5432 -U root -W |
根据提示发现,光有用户不让登录,用户需要有一个数据库,创建一个root库:
1 | create database root; |
可以在不退出psql的前提下,直接切换数据库
也可以退出psql,重新基于psql命令去切换用户以及数据库
如果要修改用户信息,或者删除用户,可以查看
1 | # 修改用户,直接基于ALTER命令操作 |
如果要查看现在的全部用户信息
权限操作
权限操作前,要先掌握一下PGSQL的逻辑结构
PostgreSQL一个数据库中有多个schema,在每个schema下都有自己的相应的表信息,权限粒度比MySQL更细一些。
在PostgreSQL中,权限的管理分为很多多层:
- server、cluster、tablespace级别:基于pg_hba.conf去配置;
- database级别:通过grant命令操作;
- namespace、schema级别:使用不多,暂不了解;
- 对象级别:通过grant命令去设置。
对database或者是对象级别做权限控制可以直接基于grant命令去操作,查看grant命令的使用帮助:
1 | # 查看grant命令 |
小任务
- 构建一个用户
- 构建一个数据库
- 在这个数据库下构建一个schema(数据库默认有一个public的schema)
- 将这个schema的权限赋予用户
- 在这个schema下构建一个表
- 将表的select,update,insert权限赋予用户
完成上述操作
1 | -- 准备用户 |
1 | -- 基于上述问题,不采用本地连接即可。 |
这种权限的赋予方式,可以用管理员用户去构建整体表结构,分配指定用户,赋予不同的权限,就不怕用户误操作了。