PostgreSQL基础(三):PostgreSQL的基础操作

举报
Lansonli 发表于 2024/10/27 11:20:32 2024/10/27
【摘要】 ​PostgreSQL的基础操作只在psql命令行(客户端)下,执行了一次\l,查看了所有的库信息。可以直接基于psql查看一些信息,也可以基于psql进入到命令行后,再做具体操作。可以直接基于psql去玩可以输入psql --help,查看psql的命令可以直接进入到命令行的原因,是psql默认情况下,就是以postgres用户去连接本地的pgsql,所以可以直接进入。下面的图是默认的连接...

PostgreSQL的基础操作

只在psql命令行(客户端)下,执行了一次\l,查看了所有的库信息。

可以直接基于psql查看一些信息,也可以基于psql进入到命令行后,再做具体操作。

可以直接基于psql去玩

可以输入psql --help,查看psql的命令
可以直接进入到命令行的原因,是psql默认情况下,就是以postgres用户去连接本地的pgsql,所以可以直接进入。
下面的图是默认的连接方式

后面都基于psql的命令行(客户端)去进行操作

命令绝对不要去背,需要使用的时候,直接找帮助文档,在psql命令行中,直接注入

\help,即可查看到数据库级别的一些命令
\?,可以查看到服务级别的一些命令 


一、用户操作

构建用户命令巨简单

-- 区别就是create user默认有连接权限,create role没有,不过可以基于选项去设置
CREATE USER 名称 [ [ WITH ] 选项 [ ... ] ]
create role 名称 [ [ WITH ] 选项 [ ... ] ]

 构建一个超级管理员用户

create user root with SUPERUSER PASSWORD 'root';

退出psql命令行

编写psql命令尝试去用root用户登录

psql -h 192.168.11.32 -p 5432 -U root -W

发现光有用户不让登录,得让用户有一个数据库,直接构建一个root库。

create database root;

可以在不退出psql的前提下,直接切换数据库 。

 

也可以退出psql,重新基于psql命令去切换用户以及数据库。

如果要修改用户信息,或者删除用户,可以查看。

-- 修改用户,直接基于ALTER命令操作
-- 删除用户,直接基于DROP命令操作

如果要查看现在的全部用户信息


二、权限操作

权限操作前,要先掌握一下PGSQL的逻辑结构。

逻辑结构图

可以看到PGSQL一个数据库中有多个schema,在每个schema下都有自己的相应的库表信息,权限粒度会比MySQL更细一些。

在PGSQL中,权限的管理分为很多多层

server、cluster、tablespace级别:这个级别一般是基于pg_hba.conf去配置

database级别:通过命令级别操作,grant

namespace、schema级别:玩的不多……不去多了解这个~~

对象级别:通过grant命令去设置

后面如果需要对database或者是对象级别做权限控制,直接基于grant命令去操作即可。

# 查看grant命令
\help grant

三、操作任务

1、要求

  • 构建一个用户(你自己名字)
  • 构建一个数据库
  • 在这个数据库下构建一个schema(数据库默认有一个public的schema)
  • 将这个schema的权限赋予用户
  • 在这个schema下构建一个表
  • 将表的select,update,insert权限赋予用户


2、操作

-- 准备用户
create user laozheng with password 'laozheng';
-- 准备数据库
create database laozheng;
-- 切换数据库
\c laozheng;
-- 构建schema
create schema laozheng;
-- 将schema的拥有者修改为laozheng用户
alter schema laozheng owner to laozheng;
-- 将laozheng库下的laozheng的schema中的表的增,改,查权限赋予给laozheng用户
grant select,insert,update on all tables in schema laozheng to laozheng;
-- 用postgres用户先构建一张表
create table laozheng.test(id int);
-- 切换到laozheng用户。
\c laozheng -laozheng 
-- 报错:
-- 致命错误:  对用户"-laozheng"的对等认证失败
-- Previous connection kept
-- 上述方式直接凉凉,原因是匹配连接方式时,基于pg_hba.conf文件去从上往下找
-- 找到的第一个是local,匹配上的。发现连接方式是peer。
-- peer代表用当前系统用户去连接PostgreSQL
-- 当前系统用户只有postgres,没有laozheng,无法使用peer连接
-- 想构建laozheng用户时,发现postgreSQL的所有文件拥有者和所属组都是postgres,并且能操作的只有拥有者

-- 基于上述问题,不采用本地连接即可。
-- 采用远程连接。
psql -h 192.168.11.32 -p 5432 -U laozheng -W
-- 这样依赖,跳过了local链接方式的匹配,直接锁定到后面的host,host的连接方式是md5,md5其实就是密码加密了。
-- 登录后,直接输入
\dn
-- 查看到当前database下有两个schema

这种权限的赋予方式,可以用管理员用户去构建整体表结构,如此一来,分配指定用户,赋予不同的权限,这样一来,就不怕用户误操了。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。