PostgreSQL 操作笔记

之前我写了一篇 MySQL操作笔记 用于记录我常用的MySQL操作,事实证明还是 很有用处的,我经常需要翻到。由于今年我的目标之一是用熟PG,我也开始使用PG,但是很多时候不记得,还需要临时去查,因此 再来记录一篇PG的操作笔记,方便以后查阅。

创建用户并授权

$ sudo -u postgres psql
$ psql
> CREATE USER 用户名 WITH ENCRYPTED PASSWORD '密码';
> CREATE DATABASE 数据库名 OWNER 用户名;

更改用户密码

$ psql
> ALTER USER 用户名 WITH PASSWORD '新密码';

允许远程访问

可能创建完数据库之后,不仅仅要在本地能访问,还希望提供服务让其它机器远程访问,编辑 /etc/postgresql/13/main/pg_hba.conf, 当然如果你的版本不是13,那么路径里的版本号就要对应替换,在最后添加一行:

host all all 0.0.0.0/0 md5

此外还需要更改配置文件 /etc/postgresql/13/main/postgresql.conf,将 #listen_addresses = 'localhost' 取消注释,改为:

listen_addresses = '*'

设置 postgres 用户密码

连接上去之后,执行 \password 命令。

备份

我在 postgres 用户下,加了一个crontab每天全量备份一次:

30 3 * * * /usr/bin/pg_dumpall | gzip -c > /data/backup/postgres/full-backup-$(date +\%F).sql.gz

常见命令

$ psql
> \l 列出数据库
> \c dbname 切换数据库
> \d 列出当前数据库所有表
> \d tablename 列出当前数据库中tablename表的表结构
> \du 列出所有用户

更多文章
  • 服务器IP被ban学到的经验
  • socks5 协议详解
  • 开启HSTS(HTTP Strict Transport Security)
  • 网络乞讨之合并支付宝和微信的收款二维码
  • 从Chrome切换到Firefox
  • nomad简明教程
  • Linux下当笔记本合上盖子之后只使用扩展显示器
  • Ubuntu 18.04 dhcp更换新IP
  • Python中的新式类(new style class)和老式类(old style class)
  • Python Requests 简明教程
  • 密码技术简明教程(三):证书和TLS
  • 密码技术简明教程(二):散列、消息认证码和数字签名
  • SEO学习笔记
  • 密码技术简明教程(一):对称加密和非对称加密
  • Kubernetes 笔记