PostGIS笔记:PostgreSQL 数据库与用户 基础操作

数据库基础操作包括数据模型的实现、添加数据、查询数据、视图应用、创建日志规则等。我这里是在Ubuntu系统学习的数据库管理。Windows平台与Linux平台在命令上几乎无差异,只是说在 Windows 上虽然也能运行良好,但在性能、稳定性、功能扩展等方面,Linux 系统通常更具优势,特别是在大型、高并发的应用场景中。

例如:在 Windows 上运行 PostgreSQL 时,某些配置参数的最大值比在 Linux 上要小;Windows 上支持的扩展种类相对较少;Linux 是 PostgreSQL 的主要发展平台,可以更灵活地配置和优化 PostgreSQL 的性能参数。Windows、Linux、macOS 等多种操作系统都支持前面安装的pgAdmin ,只是说在 Linux 上,pgAdmin通过指令:sudo apt install pgadmin3安装后,可以以桌面应用模式、服务器模式(支持多用户通过网络进行访问)和容器部署模式运行;而在 Windows 上,通常以桌面应用模式为主。

数据库官网等提供了详细的学习教程,笔记内容主要来源与参考网站如下:

bash 复制代码
https://www.postgresql.org/docs/current/index.html
https://www.pgadmin.org/docs/pgadmin4/development/index.html
https://postgis.net.cn/documentation/
https://docs.qgis.org/3.34/en/docs/training_manual/index.html

PG数据库首先需要实现模型,实现模型包括数据库和用户的创建、表的创建、索引创建等内容。最开始需要创建数据库和用户

第一步,首先启动Postgresql,并查看PG 服务的总体状态。

sql 复制代码
启动服务
sudo systemctl start postgresql@14-main
查看状态
sudo systemctl status postgresql postgresql@14-main
停止特定版本的PG
sudo systemctl stop postgresql@14-main
开机自启
sudo systemctl enable postgresql@14-main
取消开机自启
sudo systemctl disable postgresql@14-main

第二步,创建新的数据库。先登录到psql,再创建新数据库:PGLearn

sql 复制代码
sudo -u postgres psql
CREATE DATABASE PGLearn;

第三步,创建新的用户/角色(role): GIS,设置用户的密码为:mima,并给这个新用户操作PGLearn数据库所有的权限。

sql 复制代码
CREATE USER GIS WITH PASSWORD 'mima';
GRANT ALL PRIVILEGES ON DATABASE PGLearn to GIS;

角色部分权限,全部内容要参考PG官网文档:

sql 复制代码
-d, --createdb     可以创建数据库
-E, --encrypted    可以加密存储的密码
-i, --inherit      角色继承其所属角色的权限(默认)
-l, --login        角色可以登录(默认)
-P, --pwprompt     为新角色分配密码
-r, --createrole   角色可以创建新角色
-s, --superuser    角色将是超级用户

第四步,查看数据库和用户,可以看到在PG中不区分大小写,是小写的pglearn 。数据库的所有者是postgres

sql 复制代码
查看数据库列表
\l
查看用户
\du

如果要修改数据库所有者,可以使用语句:ALTER DATABASE database_name OWNER TO new_owner;。因为我们这个数据库是空的,也可以删除数据库,重建pglearn数据库时定义所有者。数据库所有者对于数据库具有:数据库对象创建、删除、修改,权限管理(权限授予、撤销、转移)等权限。

sql 复制代码
直接修改所有者
ALTER DATABASE pglearn OWNER TO GIS;
先删除数据库,再重建数据库
DROP DATABASE pglearn;
CREATE DATABASE pglearn OWNER GIS;

此外,还可以取消掉用户权限:

sql 复制代码
REMOVE ALL PRIVILEGES ON DATABASE PGLearn to GIS;
相关推荐
GBASE1 分钟前
“G”术时刻:Linux环境下通过ESQL/C方式连接南大通用GBase 8s数据库(上)
数据库
一只fish2 分钟前
MySQL 8.0 OCP 1Z0-908 题目解析(23)
数据库·mysql
不拘小节曹阿蛮3 分钟前
Ubuntu 20.04 ARM64架构下面安装mysql5.7.22
数据库
优乐美香芋味好喝24 分钟前
2025年7月8日学习笔记——模式识别与机器学习绪论
笔记·学习·机器学习
程序猿小D40 分钟前
[附源码+数据库+毕业论]基于Spring Boot+mysql+vue结合内容推荐算法的学生咨询系统
数据库·vue.js·spring boot·mysql·毕业设计·推荐算法·学生咨询系统
黄焖鸡能干四碗2 小时前
系统安全设计方案,软件系统安全设计方案
开发语言·数据库·安全·vue·系统安全
He.ZaoCha2 小时前
函数-3-日期函数
数据库·sql·mysql
paopaokaka_luck2 小时前
基于Spring Boot+Vue的巴彦淖尔旅游网站(AI问答、腾讯地图API、WebSocket及时通讯、支付宝沙盒支付)
数据库·vue.js·spring boot·websocket·mysql·毕业设计·旅游
{⌐■_■}3 小时前
【软件工程】tob和toc含义理解
前端·数据库·mysql·golang·软件工程·tidb