PostgreSQL 初体验

PostgreSQL 安装

一、核心基础

1. 简介

PostgreSQL 是开源对象关系型数据库(ORDBMS),源自加州伯克利分校,兼容 SQL 标准,支持事务、复杂查询与扩展。

2. 核心特点

  • 完全开源,许可宽松
  • 高度符合 SQL 标准,支持窗口函数、CTE、子查询
  • 数据类型丰富:JSON、数组、枚举、地理空间类型
  • MVCC 多版本并发,事务安全
  • 插件化扩展,支持 PostGIS、TimescaleDB
  • 细粒度权限、加密、审计,安全性高

3. 核心优势

高性能、高可用(主从 / 流复制)、灵活适配多场景、活跃社区、开源低成本。

4. 典型应用场景

企业 ERP/CRM、数据仓库、Web 高并发、GIS 地理信息、物联网 / 大数据。

二、逻辑结构(从上到下)

数据库集簇 → 数据库 → Schema → 表 / 视图 / 索引 / 函数等对象

  1. 数据库集簇:实例管理的所有数据库集合
  2. 数据库:默认 postgres、template0、template1
  3. Schema:隔离对象,默认 public
  4. 对象:表、索引、视图、序列、函数
  5. 表空间:逻辑存储映射物理目录
  6. OID:对象唯一标识

三、物理结构

安装目录
  • bin:命令工具
  • lib:动态库
  • share:文档、插件
  • include:头文件
  • data:数据核心目录
data 关键子目录
  • base:用户表 / 索引
  • global:全局系统表
  • pg_wal:WAL 预写日志
  • pg_tblspc:表空间链接
  • pg_xact:事务状态
关键配置文件
  • postgresql.conf:参数配置
  • pg_hba.conf:客户端认证
  • pg_ident.conf:用户映射

四、实验:安装与登录(OpenEuler 24)

实验 1:编译安装 PostgreSQL 16.3

  1. 安装依赖
bash 复制代码
yum -y install gcc gcc-* make libicu libicu-devel readline-devel zlib zlib-devel
  1. 解压并编译
bash 复制代码
tar zxvf postgresql-16.3.tar.gz
cd postgresql-16.3
./configure --prefix=/usr/local/pgsql
make && make install
  1. 创建用户与数据目录
bash 复制代码
adduser postgres
mkdir /usr/local/pgsql/data
chown postgres /usr/local/pgsql/data
  1. 配置环境变量
bash 复制代码
cat >> /etc/profile << 'EOF'
export LD_LIBRARY_PATH=/usr/local/pgsql/lib
export PATH=/usr/local/pgsql/bin:$PATH
EOF
source /etc/profile
  1. 初始化并启动
bash 复制代码
su - postgres
initdb -D /usr/local/pgsql/data
pg_ctl -D /usr/local/pgsql/data -l logfile start
  1. 登录数据库
复制代码
psql

实验 2:DNF 安装 PostgreSQL 15.12

  1. 安装
bash 复制代码
dnf install -y postgresql-server
  1. 初始化
bash 复制代码
postgresql-setup --initdb
  1. 启动并登录
bash 复制代码
systemctl start postgre
su - postgres
psql

五、常用操作速记

  • 登录:psql -U 用户名 -d 数据库名

  • 查看库:\l

  • 进入库:\c 库名

  • 查看表:\dt

  • 帮助:\help

  • 退出:\q

相关推荐
IvorySQL6 小时前
PostgreSQL 技术日报 (6月11日)|规划器扩展优化,POSETTE 大会倒计时
数据库·postgresql
胡小禾6 小时前
Redis哨兵模式下主从同步的偏差
数据库·redis·缓存
zzqssliu6 小时前
Taocarts接口限流实操:基于Redis实现API防刷与流量管控
数据库·redis·缓存
啦啦啦啦啦zzzz6 小时前
redis的持久化操作和主从复制与集群的关系及其应用
数据库·redis
IT策士6 小时前
Redis 从入门到精通:分片之道 —— Redis Cluster
数据库·redis·缓存
AOwhisky7 小时前
学习自测与解析:Redis系列第一期与第二期核心知识点详解
运维·数据库·redis·学习·云计算
kishu_iOS&AI7 小时前
LLM —— Milvmus向量数据库
数据库·人工智能·milvus
dabidai7 小时前
Docker PostgreSQL Windows 权限问题总结
windows·docker·postgresql
名不经传的养虾人7 小时前
从0到1:企业级AI项目迭代日记 Vol.46|三个检索源、缓存限流、深度整合——联网检索一日冲刺
数据库·人工智能·agent·ai编程·ai工作流·企业ai
BugShare8 小时前
Mac 上原生开发的开源免费、尽享丝滑数据库工具
数据库·macos·开源