https://zh.wikipedia.org/wiki/PostgreSQL
PostgreSQL是*的对象-关系型数据库服务器(数据库管理系统),在灵活的BSD-风格许可证下发行。它在其他开放源代码数据库系统(比如MySQL和Firebird),和专有系统比如Oracle、Sybase、IBM的DB2和Microsoft SQL Server之外,为用户又提供了一种选择。
PostgreSQL不寻常的名字导致一些读者停下来尝试拼读它,特别是那些把SQL拼读为"sequel"的人。PostgreSQL开发者把它拼读为"post-gress-Q-L"。(Audio sample,5.6k MP3)。它也经常被简略念为"postgres"。
在PostgreSQL中程序员可以用一组可观的支持语言中任何一种来写这种逻辑。
- 类似于Oracle的过程语言PL/SQL的叫做PL/PgSQL的内置语言,在处理查询密集的过程时提供了独特的优势。
- 流行脚本语言比如Perl,Python,Tcl,和Ruby的包装器,允许利用它们在字符串处理和连接到广阔的外部函数库的力量。
- 需要把复杂逻辑编译到机器代码所能提供的高性能的过程可以利用C或C++。
- 在更加深奥的方面,R统计语言的处理器允许数据库查询利用它的一组丰富的统计函数。
程序员可以把代码作为函数插入服务器中,它是使代码类似于存储过程的一个小包装器。以这种方式SQL代码可以调用(比如)C代码或反之。
- 性能增进,因为数据库引擎在一个时间一个地方调用所有的逻辑,减少了在客户和服务器之间的来回往返的次数。
- 可靠性增进,因为数据验证代码集中到一个地方,就在服务器上,而不用依赖在多个客户应用中的同步逻辑,它们甚至可能以多种编程语言写成。
- 通过向服务器增加有用的抽象,客户代码可以变得更短小和简单。
这些优势合起来可以证实PostgreSQL从编程角度是*的数据库系统。使用PostgreSQL可以显著的减少很多项目的整体编程时间,这种优势随着项目复杂而增长。
通过函数,可以在数据库服务器端执行指令程序。尽管这样的指令程序可以使用基本的SQL语句写成,但是由于其缺乏流程控制等功能,所以在PostgreSQL中引入了使用其它程序语言编写函数的能力,包括:
- 一个内置的名为PL/pgSQL的过程语言,类似于Oracle的PL/SQL;
- 包括PL/Perl,PL/PHP,PL/Python,PL/Ruby,PL/sh,PL/Tcl与PL/Scheme在内的脚本语言;
- 编译语言:C,C++,或Java(通过PL/Java)。
- R统计语言(PL/R)。
以上部分的语言,甚至可以在触发器内执行。PostgreSQL支持行返回函数:它们的输出是一系列行类型数据的集合,可以在查询中当作表来使用。函数也可以被定义成以创建者或者调用者的身份运行。在某些场合,或者其他的数据库产品中,函数也会被称为“存储过程”,但技术上这两者并未有太大分别。
吸引我注意的是上面所说的,有强大的编程能力。以前一直用 T-SQL写SP,觉得它的表达能力非常有限,正想寻找一个有强大的编程能力的数据库引擎。
官网:
https://www.postgresql.org/
https://www.postgresql.org/download/linux/redhat/
简单的安装命令,但版本不是最新的:
yum install postgresql-server
若想安装最新版本,需要添加repo.
https://yum.postgresql.org/repopackages.php
Please note that PostgreSQL YUM repository depends on EPEL repository for some packages. RHEL/CentOS/, etc.
users should install EPEL repo RPM along with PGDG repo RPMs to satisfy dependencies.
1: EPEL (Extra Packages for Enterprise Linux)
https://support.rackspace.com/how-to/install-epel-and-additional-repositories-on-centos-and-red-hat/
-
CentOS and Red Hat Enterprise Linux 6.x
wget http://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
sudo rpm -Uvh epel-release-6*.rpm -
CentOS and Red Hat Enterprise Linux 7.x
wget http://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
sudo rpm -Uvh epel-release-latest-7*.rpm
2: PGDG repo
http://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6-x86_64/pgdg-centos96-9.6-3.noarch.rpm
成功安装后会发现:
/etc/yum.repos.d
目录出了几个文件:
-rw-r--r--. 1 root root 957 12月 10 15:32 epel.repo
-rw-r--r--. 1 root root 1056 12月 10 15:32 epel-testing.repo
-rw-r--r--. 1 root root 1364 12月 10 15:57 pgdg-96-centos.repo
-rw-r--r--. 1 root root 1012 12月 10 15:45 pgdg-96-centos.repo.backup
输入命令:
# yum info postgresql96-server
若出现路径错误, 需要分别修改一下路径:
http://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6.2-x86_64/
最后成功提示包信息,说明配置成功。
最后执行:
[root@localhost yum.repos.d]# yum groupinstall "PostgreSQL Database Server 9.6 PGDG"
...
已安装:
postgresql96.x86_64 0:9.6.1-1PGDG.rhel6
postgresql96-contrib.x86_64 0:9.6.1-1PGDG.rhel6
postgresql96-libs.x86_64 0:9.6.1-1PGDG.rhel6
postgresql96-server.x86_64 0:9.6.1-1PGDG.rhel6
完毕!
说明安装成功。
安装pl/python扩展语言
/usr/pgsql-9.6/bin/
/var/lib/pgsql/9.6/data/
yum install postgresql96-plpython plpython扩展语言
安装好包之后在postgres命令行中创建语言:
create language plpythonu;
yum install postgresql96-plperl plpython扩展语言
create language plperl;
create language plperlu;
yum search postgresql
安装PL/Proxy
yum install plproxy96
启动服务:
service postgresql-9.6 initdb
service postgresql-9.6 start
设置开机启动 :
chkconfig postgresql-9.6 on
chkconfig --list | grep postgresql
参考: http://www.cnblogs.com/mchina/archive/2012/06/06/2539003.html
改配置: /var/lib/pgsql/9.6/data/postgresql.conf
listen_addresses = '*'
连接数据库:
psql -U postgres -h localhost postgres
psql -U 用户名 -h 主机IP 数据库名
若提示: psql: FATAL: Ident authentication failed for user "postgres"
将/var/lib/pgsql/9.6/data/pg_hba.conf 中 最后 ident改为md5, 如下:
79 # "local" is for Unix domain socket connections only
80 local all all ident
81 # IPv4 local connections:
82 host all all 127.0.0.1/32 md5
83 host all all 192.168.1.1/24 md5
84 # IPv6 local connections:
85 host all all ::1/128 ident
重启 service postgresql-9.6 restart
CentOS 7:
# cd /usr/pgsql-9.6/bin
# ./postgresql96-setup initdb
Initializing database ... OK
# su - postgres
-bash-4.2$ psql
postgres=# alter user postgres with password 'postgres';
# psql -h localhost -U postgres