PostgreSQL-01-入门篇-简介

打印 上一主题 下一主题

主题 843|帖子 843|积分 2531

1. PostgreSQL是什么?

PostgreSQL 是一个基于加州大学伯克利分校盘算机系开发的 POSTGRES 版本 4.2 的对象-关系型数据库管理体系 (ORDBMS)。它与 MySQL 类似,但 POSTGRES 许多先辈的概念在当时领先于其他商业数据库体系。
PostgreSQL 支持大多数 SQL 标准,并提供了许多当代特性,包括:


  • 复杂查询
  • 外键
  • 触发器
  • 可更新视图
  • 事务完备性
  • 多版本并发控制 (MVCC)
此外,PostgreSQL 具有很高的可扩展性,允许添加:


  • 新的数据类型
  • 函数
  • 操纵符
  • 聚集函数
  • 索引方法
  • 过程语言
由于其宽松的允许证,任何人都可以免费使用、修改和分发 PostgreSQL,无论是用于私家、商业照旧学术研究目的。
排名:

2. PostgreSQL 汗青

2.1. 伯克利 POSTGRES 项目

由 Michael Stonebraker 教授领导的 POSTGRES 项目是由防务高级研究项目局 (DARPA)、陆军研究办公室 (ARO)、国家科学基金会 (NSF) 以及 ESL, Inc. 共同赞助的。POSTGRES 的开发始于 1986 年,其目的是探索和实现新的数据库技术,尤其是面向对象的数据模型。
POSTGRES 经历了几轮主要的版本更新。第一个演示体系在 1987 年完成,并在 1988 年的 ACM-SIGMOD 大会上展示。1989 年 6 月发布了第一个外部可用版本 1。1990 年 6 月发布的版本 2 包含了重新设计的规则体系。版本 3 在 1991 年推出,增加了多存储管理器的支持,并改进了查询实行器和规则体系。
POSTGRES 被广泛应用于各种研究和生产情况,包括财务数据分析体系、喷气引擎性能监控软件包、小行星跟踪数据库、医疗信息数据库以及地理信息体系。它也被许多大学用于教学。此外,lllustra Information Technologies(厥后被 Informix 收购,而 Informix 现已被 IBM 所有)拿到了 POSTGRES 的代码并将其商业化。1992 年末,POSTGRES 成为了 Sequoia 2000 科学盘算项目的主要数据管理器。
随着外部用户社区的增长,代码维护的时间资源增加,为了淘汰支持负担,伯克利的 POSTGRES 项目在版本 4.2 时正式终止。
2.2. Postgres95

1994 年,Andrew Yu 和 Jolly Chen 向 POSTGRES 中添加了 SQL 语言表明器,并将源代码以新名字 Postgres95 发布到互联网上。Postgres95 是 POSTGRES 伯克利代码的开源继承者。
Postgres95 的源代码是完全的 ANSI C,代码量淘汰了 25%,许多内部修改进步了性能和可维护性。Postgres95 的 1.0.x 版本在 Wisconsin Benchmark 测试中的性能比 POSTGRES 版本 4.2 快 30-50%。除了修复错误外,还包括以下主要改进:


  • 原有的查询语言 PostQUEL 被 SQL 替代。
  • 增加了一个利用 GNU Readline 进行交互式 SQL 查询的工具 psql,很大程度上代替了旧的 monitor 程序。
  • 增加了新的前端库 libpgtcl,用于支持基于 Tcl 的客户端。
  • 彻底重写了大对象的接口。
  • 去掉了实例级的规则体系,但规则仍以重写规则的情势存在。
  • 在发布的源码中增加了一个简短教程,先容 SQL 和 Postgres95 的特性。
  • 使用 GNU make 编译,支持使用未经修补的 GCC 编译。
2.3. PostgreSQL来了

到了 1996 年,“Postgres95” 这个名字不再适用。因此,选择了一个新名字 PostgreSQL 来反映与最初的 POSTGRES 和最新的具有 SQL 能力的版本之间的关系。同时,版本号从 6.0 开始,将版本号放回到最初由伯克利 POSTGRES 项目开始的序列中。
许多人继承使用 “Postgres” 来指代 PostgreSQL(现在很少使用全大写字母),这种用法也被广泛担当为一种昵称或别名。
Postgres95 的开发重点在于辨认和解决后端代码的问题,而 PostgreSQL 的开发则转向了更具争议性的特性和功能,尽管这两个方面的工作同时进行。
3. PostgreSQL vs MySQL

PostgreSQLMySQL允许证Postgres允许(类似MIT)GPL允许性能互联网规模与Postgres相当,在极度的写入麋集型工作负载下表现更好功能在事务处理、安全性、查询优化器、JSON、CTE和WindowFunctions方面更良好。不错可扩展性PAM+扩展功能PAM易用性严谨并遵照标准宽容且遵照惯例连接模型每个进程对应一个连接每个线程对应一个连接生态繁荣的社区和更多的托管提供商大量的安装可运维性不错,学习曲线稍高一些不错,易于使用和操纵 根据 2024 年 Stack Overflow 的调研结果,PostgreSQL 已经逾越 MySQL 成为最受开发者欢迎的数据库。随着 MySQL 逐步闭源,其客户端遵照 GPL 允许协议,这意味着开发职员要么向 Oracle 付费,要么将本身的应用程序开源。相比之下,PostgreSQL 接纳了类似于 MIT 的允许协议,允许开发职员在开源或闭源产物中自由使用,这使得 PostgreSQL 成为了一种极具吸引力的选择。

PostgreSQL 的优势


  • 允许机动性:PostgreSQL 接纳了类似于 MIT 的允许协议,这使得开发职员可以在开源或闭源产物中自由使用,无需付出额外费用。
  • 性能优化:PostgreSQL 支持多种商业解决方案所需的性能优化功能,包括地理空间数据支持、无读锁并发等,这使得它被广泛应用于大型体系。
  • 复杂查询支持:对于须要实行复杂查询的体系来说,PostgreSQL 表现尤为出色。
    商业智能 (BI) 应用:在 BI 应用程序中表现出色,尤其适合须要快速读写速度的数据分析和数据堆栈应用程序,因此它也非常适用于 OLTP/OLAP 体系。
  • 混合数据类型支持:能够在单个产物中存储结构化和非结构化数据类型,支持多种数据类型,如 JSON。多年来,PostgreSQL 的一项重要创新是在 PostgreSQL 9.2 中引入了生成 JSON 数据的功能。
PostgreSQL 的功能与扩展


  • OLTP (在线事务处理):PostgreSQL 支持事务的 ACID 属性,可以进行 CRUD (创建-读取-更新-删除) 操纵。此外,它还支持一样寻常关系数据库常见的视图 (View)、物化视图 (Materialized View)、触发器 (Trigger) 和存储过程等功能。
  • OLAP (在线分析处理):PostgreSQL 可以用于 OLAP 中常用的聚合处理。基于 HTAP (混合事务/分析处理) 架构,PostgreSQL 可以在同一数据库中高效地运行 OLTP 和 OLAP 操纵。HTAP 架构打破了事务处理和分析之间的界限,使得企业能够做出更明智和更实时的商业决策,制止了传统架构中 OLTP 和 OLAP 数据库分离所带来的复杂性和耽误。
  • FDW (Foreign Data Wrapper):FDW 是 PostgreSQL 中的一个扩展,允许访问外部数据库中的表结构或数据。SQL 标准在 2003 年加入了 SQL/MED (SQL Management of External Data),用于标准化从 SQL 数据库访问长途对象的方法。PostgreSQL 9.1 支持读取长途对象,9.3 支持写入。现在,FDW 可以访问大部门关系型数据库、NoSQL 数据库和外部文本文件。
  • 流式盘算:PipelineDB 是一个用于高性能时间序列聚合的 PostgreSQL 扩展,旨在为实时报告和分析应用提供支持。
  • 地理空间:PostGIS 是 PostgreSQL 的一个空间扩展,增加了对地理对象的支持,允许在 SQL 中查询位置信息。
  • 时间序列:Timescale 扩展了 PostgreSQL 的时间序列和分析功能,比方,开发职员可以将金融数据流、市场数据与其他业务数据联合起来,构建新的应用程序并发现独特的看法。
  • 分布式表:CitusData 是一个 PostgreSQL 的扩展,将 PostgreSQL 转变为分布式数据库,支持大规模并行处理。
这些功能和扩展使得 PostgreSQL 成为一个非常有竞争力的数据库选择,无论是在商业应用照旧开源项目中。
4. 安装

   PostgreSQL 下载地址
  4.1 Windows 安装

访问上面的官方下载地址,选择对应的Windows版本下载,一路next就ok了。

4.2 linux 安装


  • 创建 PostgreSQL 安装目录
    1. mkdir -p /opt/postgresql
    2. mkdir -p /opt/postgresql/data
    3. cd /opt/postgresql/data
    复制代码
  • 下载并解压 PostgreSQL 安装包
    1. # 然后将Postgresql-14.2-Linux.tar.gz文件拖动上传到服务器中opt/postgresql下
    2. tar -zxvf Postgresql-14.2-Linux.tar.gz
    复制代码
  • 配置、编译并安装 PostgreSQL
    1. # 1. 进入解压后的目录
    2. cd postgresql-12.9/
    3. # 2. 在解压缩后的目录中执行配置命令
    4. ./configure --prefix=/opt/postgresql
    5. # 3. 编译安装,在解压目录下执行如下命令
    6. make && make install
    复制代码
          留意:

    • 如果在实行第二步出现如下错误configure: error: readline library not found 则须要实行如下命令yum -y install -y readline-devel ,然后重新实行./configure --prefix=/opt/postgresql 以及反面步调。
    • 同理如果出现configure: error: zlib library not found 则须要实行如下命令yum install zlib-devel ,然后重新实行./configure --prefix=/opt/postgresql 以及反面步调。
       
  • 安装工具
    1. # 进入解压后的目录中
    2. cd contrib
    3. # 执行如下指令
    4. make && make install
    复制代码
  • 创建用户并授权
    1. # 创建 PostgreSQL 用户
    2. groupadd postgres
    3. useradd -g postgres postgres
    4. #先回到opt目录
    5. cd /opt
    6. # 修改 PostgreSQL 目录用户
    7. chown -R postgres:postgres postgresql
    复制代码
  • 修改情况变量
    1. # 1.登录postgres账户
    2. su postgres
    3. # 2.执行指令修改环境变量
    4. vim /home/postgres/.bash_profile
    5. # 3.在文件中添加如下内容
    6. #-------------------------------------------------
    7. export PGHOME=/opt/postgresql
    8. export PGDATA=/opt/postgresql/data
    9. export PATH=$PGHOME/bin:$PATH
    10. export MANPATH=$PGHOME/share/man:$MANPATH
    11. export LANG=en_US.utf8
    12. export DATE=`date +"%Y-%m-%d %H:%M:%S"`
    13. export LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH
    14. alias rm='rm  -i'
    15. alias ll='ls -lh'
    16. #--------------------------------------------------
    17. # 4.使修改的环境变量生效
    18. source  ~/.bash_profile
    复制代码
  • 初始化数据库
    1. initdb -D /opt/postgresql/data/
    复制代码
          留意:
        如果遇到initdb: error: invalid locale settings; check LANG and LC_* environment variables 如许报错,查察下下字符有没有en_us.utf8,可以用locale -a命令查察,如果没有en_US.UTF-8,则须要完成以下操纵
       
    1. # 修改本地文件
    2. vim /etc/profile
    3. # 在这个文件里面最后一行添加
    4. export LANG=en_us.utf8
    5. #之后
    6. source /etc/profile
    复制代码
  • 配置数据库允许连接
    1. # 切换到root下,修改postgresql安装目录下的配置文件
    2. su root
    3. # 进入postgresql的data目录
    4. cd /opt/postgresql/data
    5. # 编辑postgres的配置文件
    6. vim postgresql.conf
    7. #------------------------------
    8. Listen_addresses = '*'
    9. port=5432
    10. max_connections = 100
    11. #-------------------------------
    复制代码

  • 配置连接方式
    1. vim pg_hba.conf
    2. #插入
    3. host  all  all   0.0.0.0/0    md5
    复制代码

  • 启动postgres数据库
    1. #切换用户
    2. su postgres
    3. # 进入bin目录
    4. cd /opt/postgresql/bin/
    5. # 然后执行
    6. ./pg_ctl start
    7. # 进入数据库
    8. ./psql -h localhost -p 5432 -U postgres -d admin
    9. # 执行命令修改密码
    10. ALTER USER postgres WITH PASSWORD '123456';
    11. # 退出
    12. exit;
    复制代码
  • 配置开机自启
    PostgreSQL的开机自启动脚本位于PostgreSQL源码目录的contrib/start-scripts路径下,linux文件即为linux体系上的启动脚本:

    1. # 将Linux文件复制到 /etc/init.d 目录下,并且将其重名为postgresql
    2. cp linux /etc/init.d/postgresql
    3. # 进入 /etc/init.d 目录下,修改postgresql文件
    4. cd /etc/init.d/
    5. # 编辑
    6. vim postgresql
    7. #---------------------
    8. prefix=opt/postgresql
    9. PGDATA=/opt/postgresql/data
    10. PGUSER=postgres
    11. PGLOG=$PGDATA/serverlog
    12. #---------------------
    复制代码

    添加到开机启动
    1. # 修改文件属性:
    2. chmod a+x postgresql
    3. # 添加开机启动:
    4. chkconfig --add postgresql
    5. # 重启服务器查看服务是否自启动:
    6. # reboot
    7. # 查看服务
    8. # systemctl status postgresql
    复制代码
4.3 docker安装

  1. # 创建docker-compose.yaml并用文本编辑器打开它
  2. touch docker-compose.yaml
  3. #填充以下内容,并保存
  4. version: 3 #编排版本
  5. services:  #服务组
  6.   db:
  7.         image: postgres #镜像源
  8.         container_name: postgres #容器名
  9.     restart: always #重启方式:always总是自动重启
  10.     environment: #环境变量设置
  11.       POSTGRES_USER: your-username #用户名
  12.       POSTGRES_PASSWORD: your-password #用户密码
  13.       POSTGRES_DB: your-database #数据库
  14.     ports: #端口设置
  15.          - "5432:5432" #宿主机端口:容器端口(映射)
  16. #在当前docker-compose.yaml目录下,运行以下命令以启动PostgreSQL容器
  17. docker-compose up -d
  18. #容器启动后,可以用以下命令查看容器日志:
  19. docker-compose logs -f
  20. #连接数据库
  21. psql -h localhost -U postgres -d postgres
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

拉不拉稀肚拉稀

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表