f Mysql-数据库之PostgreSQL详解 - Powered by qidao123.com技术社区

数据库之PostgreSQL详解

打印 上一主题 下一主题

主题 1849|帖子 1849|积分 5547

一、PostgreSQL介绍

PostgreSQL是一个功能强大的 开源 的关系型数据库。底层基于C实现。
PostgreSQL的开源协议和Linux内核版本的开源协议是一样的。。BDS协议,这个协议基本和MIT开源协议一样,说人话,就是你可以对PostgreSQL举行一些封装,然后商业化是收费。
PostgreSQL的名字咋来的。之前叫Ingres,后面为了办理一些ingres中的一些问题,作为后面的ingres,就起名叫postgre。
PostgreSQL版本迭代的速度比较快,现在最新的正式的发布版本,已经到了15.RELEASE。
PGSQL的版本选择一样平常有两种:


  • 假如为了稳定的运行,推荐利用12.x版本。
  • 假如想体验新特性,推荐利用14.x版本。
PGSQL答应跨版本升级,而且没有什么大问题。
PGSQL社区特别活跃,基本是三个月一发版。意味着很多常见的BUG都可以得到实时的修复。
PGSQL实在在国外利用的比较多,国内暂时还是以MySQL为主。
但是国内很多国产数据库都是基于PGSQL做的二次封装:比如华为GaussDB另有腾讯的Tbase等等。真实很多公司原来玩的Oracle,直接平转到PGSQL。同时国内的很多云产品都支持PGSQL了。
PGSQL因为开源,有很多做数据迁徙的工具,可以让你快速的从MySQL,SQLServer,Oracle直接平转到PGSQL中内部,比如pgloader这样的数据迁徙工具。
PGSQL的官方地址:https://www.postgresql.org/
PGSQL的国内社区:http://www.postgres.cn/v2/home
二、PostgreSQL和MySQL的区别

技术没有好坏之分,知识看一下是否符合你的业务,可否办理你的业务需求。其次也要查看社区的活跃度以及更新的频次。
MySQL不支持的几点内容:


  • MySQL的数据范例不够丰富。
  • MySQL不支持序列概念,Sequence。
  • 利用MySQL时,网上比较好用的插件。
  • MySQL的性能优化监控监控工具不是很多,定位问题的成本是比较高。
  • MySQL的主从复制没有一个官方的同步策略,同步问题难以办理。
  • MySQL虽然开源,but,不够彻底。
PostgreSQL相对MySQL上述问题的特点:


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

咱们只在Linux中安装,不推荐各人在Windows下安装。
Linux的版本尽量利用7.x版本,最好是7.6或者是7.8版本。
去官网找按照的方式

选择好PGSQL的版本,已经Linux的发行版本

拿到下令,麻也不管,直接扔到Linux中运行即可
  1. # 下载PGSQL的rpm包
  2. sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
  3. # 安装PGSQL12的软件程序,需要下载,需要等一会,一般不会失败,即便失败,他也会重新帮你找镜像
  4. sudo yum install -y postgresql12-server
  5. # 数据库初始化
  6. sudo /usr/pgsql-12/bin/postgresql-12-setup initdb
  7. # 设置开启启动项,并设置为开启自行启动
  8. sudo systemctl enable postgresql-12
  9. # 启动PGSQL
  10. sudo systemctl start postgresql-12
复制代码
这种属于Windows下的傻瓜式安装,基本不会出错。假如出错,大概是那些问题:


  • 安装Linux的时候,肯定要选择最小安装
  • 你的Linux不能毗连外网
  • Linux中的5432端口,大概被占用了
PostgreSQL不推荐利用root管理,在安装成功postgreSQL后,他默认会给你创建一个用户:postgres
玩PGSQL前,先切换到postgres
  1. su postgres
复制代码
奇幻到postgres用户后,直接输入psql即可进入到postgreSQL提供的客户端
  1. # 进入命令行
  2. psql
  3. # 查看有哪些库,如果是新安装的,有三个库,一个是postgres,template0,template1
  4. l  
复制代码
其次不推荐下载Windows版本去玩
假如非要下载:https://sbp.enterprisedb.com/getfile.jspfileid=1258242
四、PostgreSQL的配置

要搞两个配置信息,一个关于postgreSQL的远程毗连配置以及postgreSQL的日志日志配置。
PostgreSQL的重要配置放在数据目录下的, postgresql.conf 以及 pg_hba.conf 配置文件
这些配置文件都放在了
  1. # 这个目录下
  2. /var/lib/pgsql/12/data
复制代码

上图可以看到,postgreSQL的焦点文件,都属于postgres用户,操纵的时候,尽大概的别用root用户,容易玩出坑,尽大概先切换到postgres用户去玩。
4.1 远程毗连配置

PostgreSQL默认环境下不支持远程毗连的,这个跟MySQL几乎一样


  • MySQL给mysql.user追加用户,一样平常是采用grant的下令去玩。
  • PostgreSQL要基于配置文件修改,才能制定用户是否可以远程毗连。
直接去修改pg_hba.conf配置文件
用户以及对应数据库和毗连方式的编写模板

  1. # 第一块
  2. local:代表本地连接,host代表可以指定连接的ADDRESS
  3. # 第二块
  4. database编写数据库名,如果写all,代表所有库都可以连接
  5. # 第三块
  6. user编写连接的用户,可以写all,代表所有用户
  7. # 第四块
  8. address代表那些IP地址可以连接
  9. # 第五块
  10. method加密方式,这块不用过多关注,直接md5
  11. # 直接来个痛快的配置吗,允许任意地址的全部用户连接所有数据库
  12. host    all             all             0.0.0.0/0               md5
复制代码

为了实现远程毗连,除了用户级别的这种配置,还要针对服务级别修改一个配置
服务级别的配置在postgresql.conf
发现默认环境下,PGSQL只答应localhost毗连,直接配置为*即可办理问题

记得,为了生效,肯定要重启
  1. # postgres密码不管,直接root用户
  2. sudo systemctl restart postgresql-12
复制代码
4.2 配置数据库的日志日志

查看postgresql.conf文件

postgreSQL默认环境下,只生存7天的日志日志,循环覆盖。
  1. # 代表日志是开启的。
  2. logging_collector = on
  3. # 日志存放的路径,默认放到当前目录下的log里
  4. log_directory = 'log'
  5. # 日志的文件名,默认是postgresql为前缀,星期作为后缀
  6. log_filename = 'postgresql-%a.log'
  7. # 默认一周过后,日志文件会被覆盖
  8. log_truncate_on_rotation = on
  9. # 一天一个日志文件
  10. log_rotation_age = 1d
  11. # 一个日志文件,没有大小限制
  12. log_rotation_size = 0
复制代码
五、PostgreSQL的基操

只在psql下令行(客户端)下,执行了一次l,查看了全部的库信息
可以直接基于psql查看一些信息,也可以基于psql进入到下令行后,再做详细操纵

可以直接基于psql去玩
  1. 可以数据psql --help,查看psql的命令
  2. 可以直接进入到命令行的原因,是psql默认情况下,就是以postgres用户去连接本地的pgsql,所以可以直接进入
  3. 下面的图是默认的连接方式
复制代码

后面都基于psql的下令行(客户端)去举行操纵
下令绝对不要去背,必要利用的时候,直接找帮助文档,在psql下令行中,直接注入
  1. help,即可查看到数据库级别的一些命令
  2. ?,可以查看到服务级别的一些命令
复制代码
5.1 用户操纵

构建用户下令巨简朴
  1. # 区别就是create user默认有连接权限,create role没有,不过可以基于选项去设置
  2. CREATE USER 名称 [ [ WITH ] 选项 [ ... ] ]
  3. create role 名称 [ [ WITH ] 选项 [ ... ] ]
复制代码
构建一个超等管理员用户
  1. create user root with SUPERUSER PASSWORD 'root';
复制代码

退出psql下令行

编写psql下令尝试去用root用户登录
  1. psql -h 192.168.11.32 -p 5432 -U root -W
复制代码
发现,光有用户不让登录,得让用户有一个数据库,直接构建一个root库
  1. create database root;
复制代码

可以在不退出psql的条件下,直接切换数据库

也可以退出psql,重新基于psql下令去切换用户以及数据库
假如要修改用户信息,或者删除用户,可以查看
  1. # 修改用户,直接基于ALTER命令操作
  2. # 删除用户,直接基于DROP命令操作
复制代码
假如要查看现在的全部用户信息

5.2 权限操纵

权限操纵前,要先掌握一下PGSQL的逻辑布局
逻辑布局图

可以看到PGSQL一个数据库中有多个schema,在每个schema下都有本身的相应的库表信息,权限粒度会比MySQL更细一些。
在PGSQL中,权限的管理分为很多多层
   server、cluster、tablespace级别:这个级别一样平常是基于pg_hba.conf去配置
  database级别:通过下令级别操纵,grant
  namespace、schema级别:玩的不多……不去多相识这个~~
  对象级别:通过grant下令去设置
  后面假如必要对database或者是对象级别做权限控制,直接基于grant下令去操纵即可
  1. # 查看grant命令
  2. help grant
复制代码
小任务

构建一个用户(你本身名字)
构建一个数据库
在这个数据库下构建一个schema(数据库默认有一个public的schema)
将这个schema的权限赋予用户
在这个schema下构建一个表
将表的select,update,insert权限赋予用户
完成上述操纵

  1. -- 准备用户
  2. create user laozheng with password 'laozheng';
  3. -- 准备数据库
  4. create database laozheng;
  5. -- 切换数据库
  6. c laozheng;
  7. -- 构建schema
  8. create schema laozheng;
  9. -- 将schema的拥有者修改为laozheng用户
  10. alter schema laozheng owner to laozheng;
  11. -- 将laozheng库下的laozheng的schema中的表的增,改,查权限赋予给laozheng用户
  12. grant select,insert,update on all tables in schema laozheng to laozheng;
  13. -- 用postgres用户先构建一张表
  14. create table laozheng.test(id int);
  15. -- 切换到laozheng用户。
  16. c laozheng -laozheng
  17. -- 报错:
  18. -- 致命错误:  对用户"-laozheng"的对等认证失败
  19. -- Previous connection kept
  20. -- 上述方式直接凉凉,原因是匹配连接方式时,基于pg_hba.conf文件去从上往下找
  21. -- 找到的第一个是local,匹配上的。发现连接方式是peer。
  22. -- peer代表用当前系统用户去连接PostgreSQL
  23. -- 当前系统用户只有postgres,没有laozheng,无法使用peer连接
  24. -- 想构建laozheng用户时,发现postgreSQL的所有文件拥有者和所属组都是postgres,并且能操作的只有拥有者
复制代码

  1. -- 基于上述问题,不采用本地连接即可。
  2. -- 采用远程连接。
  3. psql -h 192.168.11.32 -p 5432 -U laozheng -W
  4. -- 这样依赖,跳过了local链接方式的匹配,直接锁定到后面的host,host的连接方式是md5,md5其实就是密码加密了。
  5. -- 登录后,直接输入
  6. dn
  7. -- 查看到当前database下有两个schema
复制代码

这种权限的赋予方式,可以用管理员用户去构建团体表布局,云云一来,分配指定用户,赋予不同的权限,这样一来,就不怕用户误操了。
六、图形化界面安装

图形化界面可以毗连PGSQL的很多,Navicat(收费)。
也可以直接利用PostgreSQL官方提供的图形化界面。(完全免费)
官方提供的:https://www.pgadmin.org/
直接点击就可以下载~~~
https://www.postgresql.org/ftp/pgadmin/pgadmin4/v6.9/windows/
傻瓜式安装~~~
打开pgAdmin

添加一个新的毗连

直接save,就可以毗连到老郑的信息

可以切换语言

七、数据范例

PGSQL支持的范例特别丰富,大多数的范例和MySQL都有对应的关系
名称
说明
对比MySQL
布尔范例
boolean,标准的布尔范例,只能存储true,false
MySQL中虽然没有对应的boolean,但是有更换的范例,数值的tinyint范例,和PGSQL的boolean都是占1个字节。
整型
smallint(2字节),integer(4字节),bigint(8字节)
跟MySQL没啥区别。
浮点型
decimal,numeric(和decimal一样一样的,精准浮点型),real(float),double precision(double),money(货币范例)
和MySQL基本也没区别,MySQL支持float,double,decimal。MySQL没有这个货币范例。
字符串范例
varchar(n)(character varying),char(n)(character),text
这里和MySQL基本没区别。
PGSQL存储的varchar范例,可以存储一个G。MySQ

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
继续阅读请点击广告

本帖子中包含更多资源

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

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

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

本版积分规则

十念

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表