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

相关推荐
xiaoshuaishuai817 小时前
C# Submodule 避坑指南
服务器·数据库·windows·c#
绩隐金17 小时前
PostgreSQL 架构原理第三期:事务与并发控制 —— MVCC、快照与锁机制
数据库
2501_9142459317 小时前
C#怎么使用属性Property C#自动属性和完整属性的区别get set怎么用【基础】
jvm·数据库·python
绩隐金18 小时前
SQL 与查询优化(PostgreSQL 篇)· 第五期
数据库
安当加密18 小时前
SQL Server 数据库安全新范式:TDE 透明加密+ DBG数据库安全网关 双重装甲
数据库·oracle
java干货18 小时前
如果光缆被挖断导致 Redis 出现两个 Master,怎么防止数据丢失?
数据库·redis·缓存
2401_8371638918 小时前
CSS如何实现网页打印样式优化_利用@media print重写布局
jvm·数据库·python
Irene199118 小时前
Oracle 21c XE 安装后默认不包含HR等示例表,CO 模式、SCOTT 模式安装过程记录
数据库·oracle
李白客18 小时前
能源系统数据库:面向智能电网与新能源场景的五大核心能力
数据库·能源
观北海19 小时前
机器人调度系统死锁卡死全复盘及解决方案
数据库·机器人