PostgreSQL简单使用
一、PostgreSQL概念
特点
开源与自由
标准符合性
数据类型丰富
事务与并发
扩展性
安全性
优势
高性能
高可用性
灵活性
社区支持
成本效益
PostgreSQL结构
多层逻辑结构
第一层:实例(xxx.xxx.xxx.xxx:port)
第二层:数据库(每个实例下可有多个相互独立的数据库)
第三层:Schema(每个数据库下包含多个Schema)
实例就是指该数据库,对外表示的ip和端口。
数据库就是数据仓库。
schema是指模式,模式将多个用户之间相同名称的对象隔离开。
tablespace是指表空间,存放数据库的一个逻辑空间,可以存放不同的数据库,对应在物理层面上是一个目录。
关系型数据库
第二代数据库是关系型数据库
实体->关系
实体是指库中的表。 关系是指,比如两张表之间存在外键,这外键就是它俩之间的关系。
第三代数据库是面向对象型数据库
对象->关系
对象是指库、表、函数等等。 关系是指,比如在库中建了个表,表中建了个视图、索引等。
Oracle、PostgreSQL都属于第二代关系型数据库和第三代关系型数据库的结合。
PostgreSQL,一个表空间可以让多个数据库使用,一个数据库可以使用多个表空间。(多对多)
二、PostgreSQL安装示例
源码编译安装
1、安装依赖包
[root@localhost ~]# dnf -y install gcc* make libicu libicu-devel readline-devel zlib zlib-devel2、编译安装
[root@localhost ~]# ls
anaconda-ks.cfg postgresql-15.4.tar.gz
[root@localhost ~]# tar zxf postgresql-15.4.tar.gz
[root@localhost ~]# cd postgresql-15.4
[root@localhost postgresql-15.4]# ls
aclocal.m4 configure contrib doc HISTORY Makefile src
config configure.ac COPYRIGHT GNUmakefile.in INSTALL README
[root@localhost postgresql-15.4]# ./configure --prefix=/usr/local/pgsql
[root@localhost postgresql-15.4]# echo $?
0
[root@localhost postgresql-15.4]# make && make install
[root@localhost postgresql-15.4]# echo $?
03、配置环境变量
[root@localhost postgresql-15.4]# adduser postgres
[root@localhost postgresql-15.4]# mkdir /usr/local/pgsql/data
[root@localhost postgresql-15.4]# ll /usr/local/pgsql/
总计 20
drwxr-xr-x. 2 root root 4096 4月21日 09:19 bin
drwxr-xr-x. 2 root root 4096 4月21日 09:21 data
drwxr-xr-x. 6 root root 4096 4月21日 09:19 include
drwxr-xr-x. 4 root root 4096 4月21日 09:19 lib
drwxr-xr-x. 6 root root 4096 4月21日 09:19 share
[root@localhost postgresql-15.4]# ll /usr/local/
总计 44
drwxr-xr-x. 2 root root 4096 11月19日 22:13 bin
drwxr-xr-x. 2 root root 4096 11月19日 22:13 etc
drwxr-xr-x. 2 root root 4096 11月19日 22:13 games
drwxr-xr-x. 2 root root 4096 11月19日 22:13 include
drwxr-xr-x. 2 root root 4096 11月19日 22:13 lib
drwxr-xr-x. 3 root root 4096 3月 1日 17:26 lib64
drwxr-xr-x. 2 root root 4096 11月19日 22:13 libexec
drwxr-xr-x. 7 root root 4096 4月21日 09:21 pgsql
drwxr-xr-x. 2 root root 4096 11月19日 22:13 sbin
drwxr-xr-x. 5 root root 4096 3月 1日 17:26 share
drwxr-xr-x. 2 root root 4096 11月19日 22:13 src
[root@localhost postgresql-15.4]# chown postgres /usr/local/pgsql/data
[root@localhost postgresql-15.4]# ll /usr/local/pgsql/
总计 20
drwxr-xr-x. 2 root root 4096 4月21日 09:19 bin
drwxr-xr-x. 2 postgres root 4096 4月21日 09:21 data
drwxr-xr-x. 6 root root 4096 4月21日 09:19 include
drwxr-xr-x. 4 root root 4096 4月21日 09:19 lib
drwxr-xr-x. 6 root root 4096 4月21日 09:19 share
[root@localhost postgresql-15.4]# cat >> /etc/profile << 'EOF'
> LD_LIBRARY_PATH=/usr/local/pgsql/lib # 配置共享库
> export LD_LIBRARY_PATH
> PATH=/usr/local/pgsql/bin:$PATH # 配置命令可搜索路径
> export PATH
> EOF
[root@localhost postgresql-15.4]# source /etc/profile4、登录数据库
[root@localhost postgresql-15.4]# su - postgres # 以postgres用户的来完成后续的操作。[postgres@localhost ~]$ /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
# 用于初始化PostgreSQL数据库目录和数据文件。
# -D选项指定了数据库的数据目录。
# initdb是postgresql的内部命令,用来创建并初始化一个新的postgresql数据库。The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.The database cluster will be initialized with locale "zh_CN.UTF-8".
The default database encoding has accordingly been set to "UTF8".
initdb: could not find suitable text search configuration for locale "zh_CN.UTF-8"
The default text search configuration will be set to "simple".Data page checksums are disabled.fixing permissions on existing directory /usr/local/pgsql/data ... ok
creating subdirectories ... ok
selecting dynamic shared memory implementation ... posix
selecting default max_connections ... 100
selecting default shared_buffers ... 128MB
selecting default time zone ... Asia/Shanghai
creating configuration files ... ok
running bootstrap script ... ok
performing post-bootstrap initialization ... ok
syncing data to disk ... okinitdb: warning: enabling "trust" authentication for local connections
initdb: hint: You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb.Success. You can now start the database server using:/usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start[postgres@localhost ~]$ echo $?
0
[postgres@localhost ~]$ /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start
# -D /usr/local/pgsql/data指定了数据目录的位置,与上条命令相同。
# start指示postgresql开始运行。
waiting for server to start.... done
server started
[postgres@localhost ~]$ echo $?
0
[postgres@localhost ~]$ /usr/local/pgsql/bin/psql
psql (15.4)
Type "help" for help.postgres=# [root@localhost ~]# dnf -y install tree[root@localhost ~]# tree -L 1 -d /usr/local/pgsql/data/
/usr/local/pgsql/data/
├── base
├── global
├── pg_commit_ts
├── pg_dynshmem
├── pg_logical
├── pg_multixact
├── pg_notify
├── pg_replslot
├── pg_serial
├── pg_snapshots
├── pg_stat
├── pg_stat_tmp
├── pg_subtrans
├── pg_tblspc
├── pg_twophase
├── pg_wal
└── pg_xact18 directories[root@localhost pgsql]# cd data
[root@localhost data]# ls
base pg_ident.conf pg_serial pg_tblspc postgresql.auto.conf
global pg_logical pg_snapshots pg_twophase postgresql.conf
pg_commit_ts pg_multixact pg_stat PG_VERSION postmaster.opts
pg_dynshmem pg_notify pg_stat_tmp pg_wal postmaster.pid
pg_hba.conf pg_replslot pg_subtrans pg_xact
[root@localhost data]# cd base
[root@localhost base]# ls
1 4 5 # 每个数据库都会在$PGDATA/base下面生成一个子目录
[root@localhost base]# cd 1
[root@localhost 1]# ls
112 2337 2616_vm 2686 3079_vm 3596 4157
113 2579 2617 2687 3080 3597 4158
1247 2600 2617_fsm 2688 3081 3598 4159
1247_fsm 2600_fsm 2617_vm 2689 3085 3599 4160
-----略postgres=# select datname,oid from pg_database;datname | oid
-----------+-----postgres | 5template1 | 1template0 | 4
(3 rows)
# 与上面的物理文件一一对应。yum安装
[root@localhost ~]# dnf -y install postgresql-server
[root@localhost ~]# postgresql-setup --initdb # 初始化数据库。* Initializing database in '/var/lib/pgsql/data' * Initialized, logs are in /var/lib/pgsql/initdb_postgresql.log
[root@localhost ~]# su - postgres
[postgres@localhost ~]$ ls
backups data initdb_postgresql.log
[postgres@localhost ~]$ cat initdb_postgresql.log
属于此数据库系统的文件宿主为用户 "postgres".
此用户也必须为服务器进程的宿主.
数据库簇将使用本地化语言 "zh_CN.UTF-8"进行初始化.
默认的数据库编码已经相应的设置为 "UTF8".
initdb: 无法为本地化语言环境"zh_CN.UTF-8"找到合适的文本搜索配置
缺省的文本搜索配置将会被设置到"simple"禁止为数据页生成校验和.修复已存在目录 /var/lib/pgsql/data 的权限 ... 成功
正在创建子目录 ... 成功
选择动态共享内存实现 ......posix
选择默认最大联接数 (max_connections) ... 100
选择默认共享缓冲区大小 (shared_buffers) ... 128MB
选择默认时区 ... Asia/Shanghai
创建配置文件 ... 成功
正在运行自举脚本 ...成功
正在执行自举后初始化 ...成功
同步数据到磁盘...成功成功。您现在可以用下面的命令开启数据库服务器:/usr/bin/pg_ctl -D /var/lib/pgsql/data -l 日志文件 start[postgres@localhost ~]$ /usr/bin/pg_ctl -D /var/lib/pgsql/data -l initdb_postgresql.log start
等待服务器进程启动 .... 完成
服务器进程已经启动
[postgres@localhost ~]$ ls
backups data initdb_postgresql.log
[postgres@localhost ~]$ cat initdb_postgresql.log
属于此数据库系统的文件宿主为用户 "postgres".
此用户也必须为服务器进程的宿主.
数据库簇将使用本地化语言 "zh_CN.UTF-8"进行初始化.
默认的数据库编码已经相应的设置为 "UTF8".
initdb: 无法为本地化语言环境"zh_CN.UTF-8"找到合适的文本搜索配置
缺省的文本搜索配置将会被设置到"simple"禁止为数据页生成校验和.修复已存在目录 /var/lib/pgsql/data 的权限 ... 成功
正在创建子目录 ... 成功
选择动态共享内存实现 ......posix
选择默认最大联接数 (max_connections) ... 100
选择默认共享缓冲区大小 (shared_buffers) ... 128MB
选择默认时区 ... Asia/Shanghai
创建配置文件 ... 成功
正在运行自举脚本 ...成功
正在执行自举后初始化 ...成功
同步数据到磁盘...成功成功。您现在可以用下面的命令开启数据库服务器:/usr/bin/pg_ctl -D /var/lib/pgsql/data -l 日志文件 start2025-03-01 11:46:22.784 CST [2368] 日志: 日志输出重定向到日志收集进程
2025-03-01 11:46:22.784 CST [2368] 提示: 后续的日志输出将出现在目录 "log"中.
[postgres@localhost ~]$ psql
psql (15.12)
输入 "help" 来获取帮助信息.postgres=# exit
[postgres@localhost ~]$ psql
psql (15.12)
输入 "help" 来获取帮助信息.postgres=#
相关文章:
PostgreSQL简单使用
一、PostgreSQL概念 特点 开源与自由 标准符合性 数据类型丰富 事务与并发 扩展性 安全性 优势 高性能 高可用性 灵活性 社区支持 成本效益 PostgreSQL结构 多层逻辑结构 第一层:实例(xxx.xxx.xxx.xxx…...

【Spring Boot】配置实战指南:Properties与YML的深度对比与最佳实践
目录 1.前言 2.正文 2.1配置文件的格式 2.2properties 2.2.1基础语法 2.2.2value读取配置文件 2.2.3缺点 2.3yml 2.3.1基础语法 2.3.2配置不同数据类型 2.3.3配置读取 2.3.4配置对象和集合 2.3.5优缺点 2.4综合练习:验证码案例 2.4.1分析需求 2.4.2…...

算法优选系列(9.BFS 解决拓扑排序)
目录 拓扑排序简介: 编辑 课程表(medium): 课程表II(medium): 火星词典(hard): 拓扑排序简介: 有向无环图(DAG图) 如上图每条边…...
(1)Java 17/18/19 新特性面试题
Java 17/18/19 新特性面试题 🚀 掌握前沿技术,成为顶尖 Java 工程师 1️⃣ Java 17/18/19 新特性价值点 👉 点击展开题目 Java 17/18/19新特性中,你认为最有价值的是哪些?请结合实际场景说明 密封类(Sealed Classes…...
LAN(局域网)和WAN(广域网)
你的问题非常清晰!我来用一个直观的比喻实际拓扑图帮你彻底理解LAN(局域网)和WAN(广域网)如何协同工作,以及路由器在其中的位置。你可以把整个网络想象成一座城市: 1. 比喻:城市交通…...

【Java高阶面经:微服务篇】7. 1秒响应保障:超时控制如何成为高并发系统的“救火队长”?
一、全链路超时建模:从用户需求到系统分解 1.1 端到端时间预算分配 黄金公式: 用户期望响应时间 = 网络传输时间 + 服务处理时间 + 下游调用时间 + 缓冲时间典型分配策略(以1秒目标为例): 环节时间预算优化目标客户端渲染100ms骨架屏(Skeleton)预渲染边缘节点(CDN)…...

力扣周赛置换环的应用,最少交换次数
置换环的基本概念 置换环是排列组合中的一个概念,用于描述数组元素的重排过程。当我们需要将一个数组转换为另一个数组时,可以把这个转换过程分解为若干个 “环”。每个环代表一组元素的循环交换路径。 举个简单例子 假设原数组 A [3, 2, 1, 4]&…...

大语言模型 12 - 从0开始训练GPT 0.25B参数量 MiniMind2 补充 训练开销 训练步骤 知识蒸馏 LoRA等
写在前面 GPT(Generative Pre-trained Transformer)是目前最广泛应用的大语言模型架构之一,其强大的自然语言理解与生成能力背后,是一个庞大而精细的训练流程。本文将从宏观到微观,系统讲解GPT的训练过程,…...
hgdbv9创建plpython3u插件后无法使用该插件创建函数
文章目录 环境症状问题原因解决方案 环境 系统平台:银河麒麟 (X86_64) 版本:9.0 症状 此问题在如下版本和安装环境出现: 安装包: hgdb-ee-9.0.1.000-build2401091440-28098d3-linux.x86_64.binOS版本&…...

SQLMesh 宏操作符详解:@IF 的条件逻辑与高级应用
SQLMesh 的 IF 宏提供了一种在 SQL 查询中嵌入条件逻辑的方法,允许根据运行时条件动态调整查询结构。本文深入探讨 IF 的语法、使用场景及实际案例,帮助开发者构建更灵活、可维护的 SQL 工作流。 1. IF 宏简介 IF 是 SQLMesh 提供的条件逻辑宏ÿ…...
nt!MiRemovePageByColor函数分析之脱链和刷新颜色表
第0部分:背景 PFN_NUMBER FASTCALL MiRemoveZeroPage ( IN ULONG Color ) { ASSERT (Color < MmSecondaryColors); Page FreePagesByColor[Color].Flink; if (Page ! MM_EMPTY_LIST) { // // Remove the first entry on the zeroe…...

【爬虫】12306自动化购票
上文: 【爬虫】12306查票-CSDN博客 下面是简单的自动化进行抢票,只写到预定票,没有写完登陆, 跳出登陆后与上述代码同理修改即可。 感觉xpath最简单,复制粘贴: 还有很多写法: 官网地址&#…...
不同消息队列保证高可用实现方案
消息队列的高可用性(High Availability, HA)是分布式系统中的核心需求,不同消息队列通过多种技术手段实现高可用。以下是主流消息队列的高可用实现方案及对比: 一、Apache Kafka 副本机制(Replication) 每个…...

【Django系统】Python+Django携程酒店评论情感分析系统
Python Django携程酒店评论情感分析系统 项目概述 这是一个基于 Django 框架开发的酒店评论情感分析系统。系统使用机器学习技术对酒店评论进行情感分析,帮助酒店管理者了解客户反馈,提升服务质量。 主要功能 评论数据导入:支持导入酒店…...

spring cloud alibaba-Geteway详解
spring cloud alibaba-Gateway详解 Gateway介绍 在 Spring Cloud Alibaba 生态系统中,Gateway 是一个非常重要的组件,用于构建微服务架构中的网关服务。它基于 Spring Cloud Gateway 进行扩展和优化,提供了更强大的功能和更好的性能。 Gat…...

c#中添加visionpro控件(联合编程)
vs添加vp控件 创建窗体应用 右键选择项 点击确定 加载CogAcqfifoTool工具拍照 设置参数保存.vpp 保存为QuickBuild或者job, ToolBlock 加载保存的acq工具 实例化相机工具类 //引入命名空间 using Cognex.VisionPro; //实例化一个相机工具类 CogAcqFifoTool cogAcqFifoTool n…...

性能测试-mysql监控
mysql常用监控指标 慢查询sql 慢查询:指执行速度低于设置的阀值的sql语句 作用:帮助定位查询速度较慢的sql语句,方便更好的优化数据库系统的性能 开启mysql慢查询日志 参数说明: slow_query_log:慢查询日志开启状态【on…...

游戏引擎学习第301天:使用精灵边界进行排序
回顾并为今天的内容做准备 昨天,我们解决了一些关于排序的问题,这对我们清理长期存在的Z轴排序问题很有帮助。这个问题我们一直想在开始常规游戏代码之前解决。虽然不确定是否完全解决了问题,但我们提出了一个看起来合理的排序标准。 有两点…...
CSS attr() 函数详解
attr() 是 CSS 中的一个函数,用于获取 HTML 元素的属性值并在样式中使用。虽然功能强大,但它的应用有一些限制和注意事项。 基本语法 element::pseudo-element {property: attr(attribute-name); } 可用场景 1. 在伪元素的 content 属性中使用&#…...

【AI生成PPT】使用ChatGPT+Overleaf自动生成学术论文PPT演示文稿
【AI生成PPT】使用ChatGPTOverleaf自动生成学术论文PPT演示文稿 文章摘要:使用ChatGPTBeamer自动生成学术论文PPT演示文稿Beamer是什么Overleaf编辑工具ChatGPT生成Beamer Latex代码论文获取prompt设计 生成结果 文章摘要: 本文介绍了一种高效利…...
流复备机断档处理
文章目录 环境症状问题原因解决方案 环境 系统平台:UOS(海光),UOS (飞腾),UOS(鲲鹏),UOS(龙芯),UOS (申威),银河麒麟svs(X86_64&…...
Linux 安装 pytorch+cuda+gpu 大模型开发环境过程记录
Linux 安装 pytorchcudagpu 大模型开发环境过程记录 2025-05-17 本文可用于生产环境,用于大模型训练开发运行。 1. 确定 OS 架构 # cat /etc/os-release NAME"Ubuntu" VERSION"20.04.6 LTS (Focal Fossa)" # uname -m x86_642. 查看磁盘空间…...

局部放大maya的视图HUD文字大小的方法
一、问题描述: 有网友问:有办法局部放大maya的字体吗比如hud中currenttime打开之后画面右下角有个frame 想放大一下能做到吗? 在 Maya 中,可以通过自定义 HUD(Heads-Up Display)元素的字体大小来局部放大特…...
数学复习笔记 16
前言 例题真是经典。 background music 《青春不一样》 2.28 算一个行列式,算出来行列式不等于零,这表示矩阵式可逆的。但是这个算的秩是复合的,感觉没啥好办法了,我直接硬算了,之后再看解析积累好的方法。算矩阵…...

初识Linux · NAT 内网穿透 内网打洞 代理
目录 前言: 内网穿透和打洞 NAPT表 内网穿透 内网打洞 正向/反向代理 前言: 本文算是网络原理的最后一点补充,为什么说是补充呢,因为我们在前面第一次介绍NAT的时候详细介绍的是报文从子网到公网,却没有介绍报文…...

STM32接收红外遥控器的遥控信号
经过几天早晨的学习,终于把遥控器的红外信号给搞通了,特此记录一下;其实说白了,红外遥控就是高低电平的信号,用时间来区分是二进制的0还是1;然后把这些0或1,在组装成一个32位的数基本就算是完事…...

Redis从入门到实战 - 高级篇(下)
一、Redis键值设计 1. 优雅的key结构 Redis的Key虽然可以自定义,但最好遵循下面几个最佳实践约定: 遵循基本格式:[业务名称]:[数据名]:[id]长度不超过44字节不包含特殊字符 例如:我们的登录业务,保存用户信息&…...
NGINX常用功能—笔记
NGINX 是一款高性能的开源 Web 服务器和反向代理服务器,常用于处理高并发场景,其功能丰富且灵活。以下是 NGINX 的常用功能及详细说明: 一、静态资源服务器 功能说明:直接处理 HTML、CSS、JavaScript、图片、视频等静态文件请求&a…...
JVM 性能问题排查实战10连击
🗂️ 目录 前言:理论掌握只是起点,定位能力才是核心全局排查模型:三步法1️⃣Full GC 频繁触发:老年代压力过大2️⃣ OOM 爆炸:元空间泄漏 or 缓存未清理3️⃣ CPU 飙升却不是 GC:线程阻塞或热方…...
【jvm第8集】jvm调优工具(图形化工具)
文章目录 一、JVM 调优图形化工具分类二、JDK 自带工具JConsoleVisualVM 三、第三方工具MAT(Memory Analyzer Tool)JProfiler(商业工具)YourKit(商业工具) 四、APM工具全链路监控与智能运维(AIO…...