PostgreSQL 入门

2023-09-14 11:10:14

PostgreSQL介绍

PostgreSQL是一个功能强大的 开源 的关系型数据库,底层基于C实现。其开源协议和Linux内核版本的开源协议是一样的,简单来说就是:可以对PostgreSQL进行一些封装,然后商业化是收费。

PostgreSQL之前叫Ingres,后面为了解决一些ingres中的一些问题,作为后面的ingres,就起名叫PostgreSQL。

PostgreSQL版本迭代的速度比较快,现在最新的正式的发布版本,已经到了15.RELEASE。

PostgreSQL的版本选择一般有两种:

  • 如果为了稳定的运行,推荐使用12.x版本。
  • 如果想体验新特性,推荐使用14.x版本。

PostgreSQL的官方地址:https://www.postgresql.org/

PostgreSQL的国内社区:http://www.postgres.cn/v2/home

PostgreSQL和MySQL的区别

技术没有好坏之分,只是看一下是否符合你的业务,能否解决你的业务需求。其次也要查看社区的活跃度以及更新的频次。

MySQL不支持的几点内容:

  • MySQL的数据类型不够丰富。
  • MySQL不支持序列概念,Sequence。
  • 使用MySQL时,网上比较好用的插件。
  • MySQL的性能优化监控工具不是很多,定位问题的成本是比较高。
  • MySQL的主从复制没有一个官方的同步策略,同步问题难以解决。
  • MySQL虽然开源,但是不够彻底。

PostgreSQL相对MySQL上述问题的特点:

  • PostgreSQL的数据类型丰富。
  • PostgreSQL是有序列的概念的。
  • PostgreSQL的插件特别丰富。
  • PostgreSQL支持主从复制的同步操作,可以实现数据的0丢失。
  • PostgreSQL的MVCC实现和MySQL不大一样。PostgreSQL一行数据会存储多个版本。最多可以存储40亿个事务版本。

PostgreSQL的安装

推荐在Linux中安装,Linux的版本尽量使用7.x版本,最好是7.6或者是7.8版本。根据官网的引导进行安装:

image.png

填写版本、平台等信息。拿到命令直接执行

image.png

# 下载PGSQL的rpm包
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
# 安装PGSQL12的软件程序,需要下载,需要等一会,一般不会失败,即便失败,他也会重新帮你找镜像
sudo yum install -y postgresql12-server
# 数据库初始化
sudo /usr/pgsql-12/bin/postgresql-12-setup initdb
# 设置开启启动项,并设置为开启自行启动
sudo systemctl enable postgresql-12
# 启动PGSQL
sudo systemctl start postgresql-12

这种方式基本不会出错。如果出错,可能是以下几个问题:

  • Linux没有连接外网
  • Linux中的5432端口,可能被占用了

PostgreSQL不推荐使用root管理,在安装成功后,默认会创建一个用户:postgres ,进行操作时切换到该账户

su postgres

直接输入psql即可进入到postgreSQL提供的客户端

# 进入命令行
psql
# 查看有哪些库,如果是新安装的,有三个库,一个是postgres,template0,template1
\l  

不推荐下载Windows版本去玩

如果非要下载:https://sbp.enterprisedb.com/getfile.jsp?fileid=1258242

PostgreSQL的配置

要关注两个配置信息,一个关于PostgreSQL的远程连接配置以及postgreSQL的日志配置。

PostgreSQL的主要配置放在数据目录下的, postgresql.conf 以及 pg_hba.conf 配置文件

这些配置文件都放在了这个目录下

/var/lib/pgsql/12/data

image.png

上图可以看到,postgreSQL的核心文件,都属于postgres用户,操作的时候,尽可能的别用root用户,容易出坑,尽可能先切换到postgres用户。

远程连接配置

PostgreSQL默认情况下不支持远程连接的,这个跟MySQL几乎一样

  • MySQL给mysql.user追加用户,一般是采用grant的命令。
  • PostgreSQL要基于配置文件修改,才能制定用户是否可以远程连接。

直接去修改pg_hba.conf配置文件

用户以及对应数据库和连接方式的编写模板

image.png

local:代表本地连接,host代表可以指定连接的ADDRESS
database编写数据库名,如果写all,代表所有库都可以连接
user编写连接的用户,可以写all,代表所有用户
address代表那些IP地址可以连接
method加密方式,这块不用过多关注,直接md5
# 如果为了省事,直接来个痛快的配置,允许任意地址的全部用户连接所有数据库
host    all             all             0.0.0.0/0               md5

image.png

为了实现远程连接,除了用户级别的这种配置,还要针对服务级别修改一个配置

服务级别的配置在postgresql.conf

image.png发现默认情况下,PGSQL只允许localhost连接,直接配置为*即可解决问题

image.png

为了生效,一定要重启

# postgres密码不管,直接root用户
sudo systemctl restart postgresql-12

配置数据库的日志

查看postgresql.conf文件

image.png

postgreSQL默认情况下,只保存7天的日志,循环覆盖。

# 代表日志是开启的。
logging_collector = on
# 日志存放的路径,默认放到当前目录下的log里
log_directory = 'log'
# 日志的文件名,默认是postgresql为前缀,星期作为后缀
log_filename = 'postgresql-%a.log'
# 默认一周过后,日志文件会被覆盖
log_truncate_on_rotation = on
# 一天一个日志文件
log_rotation_age = 1d
# 一个日志文件,没有大小限制
log_rotation_size = 0

PostgreSQL基本操作

只在psql命令行(客户端)下,执行了一次\l,查看了所有的库信息

可以直接基于psql查看一些信息,也可以基于psql进入到命令行后,再做具体操作

image.png 命令不用背,需要使用的时候,直接找帮助文档,在psql命令行中,直接输入

\help,即可查看到数据库级别的一些命令
\?,可以查看到服务级别的一些命令

用户操作

构建用户命令

# 区别就是create user默认有连接权限,create role没有,不过可以基于选项去设置
CREATE USER 名称 [ [ WITH ] 选项 [ ... ] ]
create role 名称 [ [ WITH ] 选项 [ ... ] ]

构建一个超级管理员用户

create user root with SUPERUSER PASSWORD 'root';

image.png

编写psql命令尝试去用root用户登录

psql -h 192.168.11.32 -p 5432 -U root -W

这时候会发现光有用户不让登录,得让用户有一个数据库,直接构建一个root库

create database root;

权限操作

权限操作前,要先掌握一下PostgreSQL的逻辑结构

逻辑结构图
image.png

可以看到PostgreSQL一个数据库中有多个schema,在每个schema下都有自己的相应的库表信息,权限粒度会比MySQL更细一些。

在PGSQL中,权限的管理分为很多多层

server、cluster、tablespace级别:这个级别一般是基于pg_hba.conf去配置

database级别:通过命令级别操作,grant

namespace、schema级别:玩的不多……不去多了解这个~~

对象级别:通过grant命令去设置

后面如果需要对database或者是对象级别做权限控制,直接基于grant命令去操作即可

# 查看grant命令
\help grant

图形化界面安装

图形化界面可以连接PGSQL的很多,Navicat(收费),也可以直接使用PostgreSQL官方提供的图形化界面(完全免费)。

下载官方提供的各操作系统的版本,进行傻瓜式安装

image.png

添加一个新的连接

image.png

总结

PostgreSQL其实在国外使用的比较多,国内暂时还是以MySQL为主。但是国内很多国产数据库都是基于PostgreSQL做的二次封装,比如:华为GaussDB还有腾讯的Tbase等等。很多公司原来玩的Oracle,直接平转到PostgreSQL,而且国内的很多云产品都支持PostgreSQL了。

因为开源,有很多做数据迁移的工具,可以让你快速的从MySQL,SQLServer,Oracle直接平转到PostgreSQL中内部,比如pgloader这样的数据迁移工具。

更多推荐

学习笔记|外部中断|INT0|中断列表|STC32G单片机视频开发教程(冲哥)|第十五集:中断系统和外部中断

文章目录1.中断和中断系统1.1什么是中断?1.2什么是中断系统1.3中断系统的优点1.4中断系统包含哪些中断源1.5.中断次序2.什么是外部中断3.外部中断的用法4.外部中断的用法新的测试场景完整代码总结课后练习:上节课我们学完了GPIO的矩阵按键,已经把这个GPIO的一个外设全都已经学完了今天开始我们要学习这个单片

COVID疫苗加强针来袭,是否该接种?

Sience子刊新研究揭示:COVID-19病毒影响人体线粒体功能,或成治疗新途径NatureMedicine:脑雾、记忆和注意力不集中可能是新冠感染引发的血栓导致的Nature揭秘--为什么有些白人感染新冠病毒后不会生病SARS-CoV-2重复感染将为常态整个北半球,公卫人员正在紧锣密鼓地推进秋季COVID-19疫苗

NLP进阶,使用TextRNN和TextRNN_ATT实现文本分类

TextRNNTextRNN仅仅是将WordEmbedding后,输入到双向LSTM中,然后对最后一位的输出输入到全连接层中,在对其进行softmax分类即可,模型如下图:代码:classRNN(nn.Module):def__init__(self,vocab_size,embedding_dim,hidden_di

SpringMVC学习|Servlet回顾、理解SpringMVC小demo、SpringMVC原理

Servlet回顾创一个空的maven父工程,导入相关依赖,测试的、spring的、servlet的、jsp以及jstl标签的。创建一个空的maven子项目,并添加web支持为了保险起见,在子项目中添加servlet和jsp的依赖编写一个Servlet类,实现HttpServlet接口获取前端参数,以及重定向,这里为了

SpringMVC中的JSR303与拦截器的使用

一,JSR303的概念JSR303是Java中的一个标准,用于验证和校验JavaBean对象的属性的合法性。它提供了一组用于定义验证规则的注解,如@NotNull、@Min、@Max等。在SpringMVC中,可以使用JSR303注解对请求参数进行校验。1.2为什么要使用JSR303?(更加理解)前端不是已经校验过数据

(第十一天)初识SpringMVC SSM框架的学习与应用(Spring + Spring MVC + MyBatis)-Java EE企业级应用开发学习记录

SSM框架的学习与应用(Spring+SpringMVC+MyBatis)-JavaEE企业级应用开发学习记录(第十一天)初识SpringMVC今天我们要来学习一下SSM框架的最后一个框架SpringMVC一、初认SpringMVC基本概念:​SpringMVC(Model-View-Controller)是一个用于构

跟着AIGC学Linux:简介(一)

文章目录1.Linux内核的历史2.基本概念3.发行版4.Linux应用领域5.LinuxVSWindows横向对比表格:1.Linux内核的历史Linux内核最初由一位名叫LinusTorvalds的芬兰计算机科学家于1991年创建。当时,Torvalds是一名赫尔辛基大学的学生,他在寻找一个类似于UNIX操作系统的

在适用于 Linux 的 Windows 子系统 (WSL2) 上安装 Node.js

🎬岸边的风:个人主页🔥个人专栏:《VUE》《javaScript》⛺️生活的理想,就是为了理想的生活!目录安装WSL2安装Windows终端(可选)安装nvm、node.js和npm替代版本管理器安装VisualStudioCode有用的VSCode扩展设置Git(可选)如果你是使用Node.js的专业人士、发现性

【Linux】查看系统各种信息的常用命令 (CPU、内存、进程、网口、磁盘、硬件、等等)

Linux是一种开源的类Unix操作系统,它有很多不同的发行版,如Ubuntu、CentOS、Debian等。Linux系统提供了很多命令行工具,可以让用户方便地查看和管理系统的各种信息,如硬件配置、内存使用、进程状态、网络连接等。本文将介绍一些常用的命令,以及它们的用法和示例。系统基本信息:unameLinux发行版

汽车行业数据治理方案,助力车企研产供销数据一体化

随着数字技术的不断革新和应用,汽车行业已转向大数据、新技术寻求生产力突破,以电动化、网联化、智能化、共享化为标志的“汽车新四化”,为汽车行业带来了翻天覆地的变化。如何抓住“新四化”的机会,在汽车产业变革中赢得先机,数据的智能化应用是关键。然而原生态的汽车行业大数据多且杂,车企在“市场规划、设计、制造、销售、维护”产品全

【kafka】kafka重要的集群参数配置

如何规划Kafka对于实际应用的生产环境中,需要尽量先规划设计好集群,避免后期业务上线后费力调整。在考量部署方案时需要通盘考虑,不能仅从单个维度上进行评估,下面是几个重要的维度的考量和建议:这里重点说说操作系统的因素。Linux系统比其他系统(特别是Windows系统)更加适合部署Kafka,主要体现在三个方面:I/O

热文推荐