软件  | 版本  | 
|---|---|
CentOS  | 7.6 Release  | 
PostgreSQL  | 12.x  | 
软件  | 版本  | 
|---|---|
CentOS  | CentOS 7.x  | 
PostgreSQL  | 9.x-12.x  | 
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpmsudo yum install -y postgresql12 postgresql12-server安装PostgreSQL 11就是 yum install postgresql12 postgresql12-server 安装PostgreSQL 9.5就是 yum install postgresql95 postgresql95-server 依此类推
sudo /usr/pgsql-12/bin/postgresql-12-setup initdb 
#Initializing database ... OK#启动PostgreSQL服务
sudo systemctl start postgresql-12
#设置PostgreSQL服务为开机启动
sudo systemctl enable postgresql-129.x版本的服务名是postgresql-9.x
PostgreSQL安装成功之后,会默认创建一个名为postgres的Linux用户,初始化数据库后,会有名为postgres的数据库,来存储数据库的基础信息,例如用户信息等等,相当于MySQL中默认的名为mysql数据库。
postgres数据库中会初始化一名超级用户postgres
为了方便我们使用postgres账号进行管理,我们可以修改该账号的密码
通过su命令切换linux用户为postgres会自动进入命令行
su postgrespsqlALTER USER postgres WITH PASSWORD 'NewPassword';sudo firewall-cmd --add-port=5432/tcp --permanent
sudo firewall-cmd --reload#修改配置文件
vi /var/lib/pgsql/12/data/postgresql.conf
#将监听地址修改为*
#默认listen_addresses配置是注释掉的,所以可以直接在配置文件开头加入该行
listen_addresses='*'#修改配置文件
vi /var/lib/pgsql/12/data/pg_hba.conf
#在问价尾部加入
host  all  all 0.0.0.0/0 md5#重启PostgreSQL服务
sudo systemctl restart postgresql-12配置完成后即可使用客户端进行连接
启动SQL shell:
su postgres
psql#创建数据库
CREATE DATABASE mydb;
#查看所有数据库
\l
#切换当前数据库
\c mydb
#创建表
CREATE TABLE test(id int,body varchar(100));
#查看当前数据库下所有表
\d#新建用户
CREATE USER test WITH PASSWORD 'test';
#赋予指定账户指定数据库所有权限
GRANT ALL PRIVILEGES ON DATABASE mydb TO test;
#移除指定账户指定数据库所有权限
REVOKE ALL PRIVILEGES ON DATABASE mydb TO test权限代码:SELECT、INSERT、UPDATE、DELETE、TRUNCATE、REFERENCES、TRIGGER、CREATE、CONNECT、TEMPORARY、EXECUTE、USAGE