跳至主要内容

PostgreSQL 入门


https://dinfratechsource.com/2018/11/10/installing-postgresql-9-4-phppgadmin-in-centos-7/


       初次安装后,默认生成一个名为postgres的数据库和一个名为postgres的数据库管理员用户,密码随机。这里需要注意的是,同时还生成了一个名为postgres的Linux系统用户

[root@kpsA ~]# cat /etc/passwd|grep postgres
postgres:x:26:26:PostgreSQL Server:/var/lib/pgsql:/bin/bash

修改linux系统postgres用户的密码

步骤一:删除用户postgres的密码
[root@kpsA ~]# sudo passwd -d postgres
Removing password for user postgres.
passwd: Success
步骤二:设置用户postgres的密码,根据系统提示输入新的密码
[root@kpsA ~]# sudo -u postgres passwd
Changing password for user postgres.
New password: 
Retype new password: 
passwd: all authentication tokens updated successfully.


# Linux登录用户切换到postgres用户sudo su - postgres,退出exit|logout
[root@kpsA ~]# sudo su - postgres
Last login: Mon Nov 11 16:11:30 CST 2019 on pts/3

# 使用psql命令登录PostgreSQL控制台
-bash-4.2$ psql
psql (9.2.13)
输入 "help" 来获取帮助信息.


# 登录还可以用sudo -u postgres psql 或者 psql -U postgres
# 相当于系统用户postgres以同名数据库用户的身份,登录数据库,这是不用输入密码的。如果一切正常,系统提示符会变为"postgres=#",数据库为=#表示这时已经进入了数据库控制台

当前数据库中所有表信息
select * from pg_tables;

查看数据库信息
select version();

postgres=# help
您正在使用psql, 这是一种用于访问PostgreSQL的命令行界面
键入: \copyright 显示发行条款
       \h 显示 SQL 命令的说明
       \? 显示 pgsql 命令的说明
       \g 或者以分号(;)结尾以执行查询
       \q 退出


postgres=# \?
一般性
  \copyright            显示PostgreSQL的使用和发行许可条款
  \g [文件] or;     执行查询 (并把结果写入文件或 |管道)
  \h [名称]          SQL命令语法上的说明,用*显示全部命令的语法说明
  \q             退出 psql

查询缓存区
  \s [文件]        显示历史记录或将历史记录保存在文件中
postgres-# \s
select version():
...

  \w 文件          将查询缓存区的内容写入文件


资讯性
  (选项: S = 显示系统对象, + = 其余的详细信息)
  \db[+]  [模式]     列出表空间
postgres-# \db
                                       List of tablespaces
          Name          |         Owner          |                   Location                    
------------------------+------------------------+-----------------------------------------------
 FWKP_310100000000002_5 | fwkp_310100000000002_5 | /var/lib/pgsql/data/TS_FWKP_310100000000002_5
 pg_default             | postgres               | 
 pg_global              | postgres               | 
(3 rows)

postgres-# \db[+]
                                                        List of tablespaces
          Name          |         Owner          |                   Location                    | Access privileges | Description 
------------------------+------------------------+-----------------------------------------------+-------------------+-------------
 FWKP_310100000000002_5 | fwkp_310100000000002_5 | /var/lib/pgsql/data/TS_FWKP_310100000000002_5 |                   | 
 pg_default             | postgres               |                                               |                   | 
 pg_global              | postgres               |                                               |                   | 

(3 rows)

  \du[+]  [PATTERN]      列出角色
postgres-# \du
                                    List of roles
       Role name        |                   Attributes                   | Member of 
------------------------+------------------------------------------------+-----------
 fwkp_310100000000002_5 | Create role, Create DB                         | {}
 postgres               | Superuser, Create role, Create DB, Replication | {}

postgres-# \du[+]
                                           List of roles
       Role name        |                   Attributes                   | Member of | Description 
------------------------+------------------------------------------------+-----------+-------------
 fwkp_310100000000002_5 | Create role, Create DB                         | {}        | 

 postgres               | Superuser, Create role, Create DB, Replication | {}        | 



  \l[+]                列出所有的数据库
postgres-# \l
                                               List of databases
          Name          |         Owner          | Encoding |   Collate   |    Ctype    |   Access privileges   
------------------------+------------------------+----------+-------------+-------------+-----------------------
 fwkp_310100000000002_5 | fwkp_310100000000002_5 | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | 
 postgres               | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | 
 template0              | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/postgres          +
                        |                        |          |             |             | postgres=CTc/postgres
 template1              | postgres               | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/postgres          +
                        |                        |          |             |             | postgres=CTc/postgres
(4 rows)


我们可以使用 \c + 数据库名 来进入数据库连接
  \c[onnect] {[DBNAME|- USER|- HOST|- PORT|-] | conninfo}
                         connect to new database (currently "postgres")
postgres-# \c
You are now connected to database "postgres" as user "postgres".
  \encoding [编码名称] 显示或设定客户端编码
postgres-# \encoding
UTF8
  \password [USERNAME]  安全地为用户改变口令
postgres=# \password postgres
Enter new password: 
Enter it again: 
  \conninfo              显示当前连接的相关信息
postgres=# \conninfo

You are connected to database "postgres" as user "postgres" via socket in "/var/run/postgresql" at port "5432".


变量
  \set [名称 [值数]] 设定内部变量,若无参数则列出全部变量
postgres=# \set
AUTOCOMMIT = 'on'
PROMPT1 = '%/%R%# '
PROMPT2 = '%/%R%# '
PROMPT3 = '>> '
VERBOSITY = 'default'
VERSION = 'PostgreSQL 9.2.13 on x86_64-redhat-linux-gnu, compiled by gcc (GCC) 4.8.3 20140911 (Red Hat 4.8.3-9), 64-bit'
DBNAME = 'postgres'
USER = 'postgres'
PORT = '5432'
ENCODING = 'UTF8'



外机pgAdmin访问postgres


修改数据库管理员PostgreSQL密码

登录数据库psql -U postgres
方法一:
postgres=# alter user postgres with password 'postgres';
ALTER ROLE
方法二:
postgres=# \password postgres
Enter new password: 
Enter it again: 


修改postgresql.conf文件

查找postgresql.conf文件位置
[root@kpsA ~]# find / -name 'postgresql.conf'
/usr/lib/tmpfiles.d/postgresql.conf
/var/lib/pgsql/data/postgresql.conf
[root@kpsA ~]# vi /var/lib/pgsql/data/postgresql.conf

在连接设置下编辑或添加一行listen_addresses = '*',使PostgreSQL可以接受来自任意IP的连接请求
# - Connection Settings -

listen_addresses = '*'
# what IP address(es) to listen on;
# comma-separated list of addresses;
# defaults to 'localhost'; use '*' for all
# (change requires restart)
# port = 5432 # (change requires restart)
# Note: In RHEL/Fedora installations, you can't set the port number here;


修改pg_hba.conf文件
pg_hba.conf,位置与postgresql.conf相同,虽然上面配置允许任意地址连接PostgreSQL,但是这在pg中还不够,我们还需在pg_hba.conf中配置服务端允许的认证方式。任意编辑器打开该文件,编辑或添加下面一行。修改为上面内容后即可以对任意IP访问进行密码验证

[root@kpsA ~]# vi /var/lib/pgsql/data/pg_hba.conf

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            md5
host    all             all             0.0.0.0/0            md5
# IPv6 local connections:
host    all             all             ::1/128                 ident
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local   replication     postgres                                peer
#host    replication     postgres        127.0.0.1/32            ident
#host    replication     postgres        ::1/128                 ident




在防火墙上将PostgreSQL监听的端口放开
firewall-cmd --zone=public --add-port=5432/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-ports
systemctl restart firewalld

执行完以上操作后,运行systemctl restart postgresql重启PostgreSQL服务后,允许外网访问的配置就算生效了


评论

此博客中的热门博文

学习地址

清华大学计算机系课程攻略 https://github.com/PKUanonym/REKCARC-TSC-UHT 浙江大学课程攻略共享计划 https://github.com/QSCTech/zju-icicles https://home.unicode.org/ 世界上的每个人都应该能够在手机和电脑上使用自己的语言。 http://codecanyon.net   初次看到这个网站,小伙伴们表示都惊呆了。原来代码也可以放在网上卖的?!! 很多coder上传了各种代码,每个代码都明码标价。看了下销售排行,有的19刀的卖了3万多份,额di神啊。可以看到代码的演示效果,真的很漂亮。代码以php、wordpress主题、Javascript、css为主,偏前台。 https://www.lintcode.com/ 算法学习网站,上去每天刷两道算法题,走遍天下都不怕。 https://www.codecademy.com/ 包含在线编程练习和课程视频 https://www.reddit.com/ 包含有趣的编程挑战题,即使不会写,也可以查看他人的解决方法。 https://ideone.com/ 在线编译器,可运行,可查看代码示例。 http://it-ebooks.info/ 大型电子图书馆,可即时免费下载书籍。 刷题 https://github.com/jackfrued/Python-100-Days https://github.com/kenwoodjw/python_interview_question 面试问题 https://github.com/kenwoodjw/python_interview_question https://www.journaldev.com/15490/python-interview-questions#python-interpreter HTTP 身份验证 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Authentication RESTful 架构详解 https://www.runoob.com/w3cnote/restful-architecture.html https://www.rosettacode.org/wiki/Rosetta_C...

PDF处理

虚拟pdf打印机 pdfFactory  https://fineprint.com PDFCreator  https://www.pdfforge.org 开源 cutepdf https://www.cutepdf.com/index.htm Doro PDF Writer http://www.the-sz.com/products/doro PdfScribe  https://github.com/stchan/PdfScribe/releases pdf阅读器 Sumatra PDF https://www.sumatrapdfreader.org/ 为什么 Python 用于 PDF 处理  如您所知,PDF 处理属于文本分析。 大多数文本分析库或框架仅使用 Python 设计。 这为文本分析提供了优势。 还有一件事,您永远无法在现有的机器学习或自然语言处理框架中直接处理 pdf。 除非他们为此证明了显式接口。 我们必须先将pdf转换为文本。 我们可以使用下述任何库轻松实现这一点。 在线转换pdf Sejda https://www.sejda.com/pdf-editor 每个文档 200 页的免费限制 https://www.pdf2go.com/ https://tools.pdfforge.org/extract-text PDF24 Tools https://tools.pdf24.org/zh/ 免费且易于使用的在线PDF工具 FreeOCR http://www.paperfile.net/ 适用于Windows的免费光学字符识别软件,支持大多数Twain扫描仪的扫描,还可以打开大多数扫描的PDF和多页Tiff图像以及流行的图像文件格式,FreeOCR输出纯文本,可以直接导出为Microsoft Word格式。 不支持中文 wkhtmltopdf 和 wkhtmltoimage 是使用 QT Webkit 渲染引擎将 HTML 渲染为 PDF 和各种图像格式的命令行工具。这些完全“无头”运行,不需要显示或显示服务。 https://wkhtmltopdf.org/ django-wkhtmltopdf 允许 Django 站点输出动态 PDF。它利用 wkhtmltopdf 库,允许您使用您知道...

安卓 之 apk下载、ADB、 scrcpy

Apk下载 下载离线安装apk https://www.apkmirror.com/ 免费和安全的Android APK下载 https://apkpure.com/ 被暴雷,有植入 https://apps.evozi.com/apk-downloader/ 可以将Google Play( https://play.google.com )中的apk文件所在网址直接下载到台式机和设备上 https://f-droid.org/zh_Hans/ F-Droid 是一个 Android 平台上 FOSS(Free and Open Source Software,自由开源软件)的目录,并提供下载安装支持。使用客户端可以更轻松地浏览、安装及跟进设备上的应用更新。 https://gitlab.com/AuroraOSS/AuroraStore Aurora商店 是Google Play商店的非官方FOSS客户,设计典雅。 Aurora商店不仅下载,更新和搜索Play商店等应用 https://github.com/OpenTracksApp/OpenTracks OpenTracks是一款运动跟踪应用程序,完全尊重您的隐私。 Tasker https://tasker.joaoapps.com/ 是一款适用于Android的应用程序,它可以根据用户定义的配置文件中的上下文、可点击或定时的主屏幕小部件来执行任务。它无需root或特殊的主屏幕就能控制Android设备。 AsciiCam AsciiCam可以从您的相机指向的任何位置实时生成ASCII图像。选择黑白,原色或全彩,拍照,并将其作为图像或HTML共享。您还可以在库中创建ASCII版本的图片,并且每次使用标准相机应用程序拍摄照片时,也可以选择自动生成ASCII版本。 AsciiCam是完全免费和开源的。 Apk1安装器 优化微信apk文件接收体验。 微信收到apk文件会加 ".1" 后缀导致打不开,必须自己手动找到文件重命名去掉后缀。 使用本安装器就可以在微信内,潇洒地点击直接打开。甚至可以在安装器内浏览apk1文件历史接收记录。 ADB ADB全名是 Android Debug Bridge,是开发或使用Android时很常用的工具。可以从电脑通过USB连线到Android手机上 https:...