绝对蓝屏(黄华栋) < ihweb@cnfug.org >
在*NIX 系统中,相信大家都对Mysql 十分熟悉和经常使用。或许很多文章都拿Mysql 和 PostgreSQL来做比较,我个人觉得任何比较都是相对的,各有所长,没必要做出比较。
我只是接触PostgreSQL是因为我的一个朋友(夜猫子)极力推荐,而且我也想试试不同的数据库。下面就把我初探PostgreSQL的过程和大家分享。
其实学习想认识PostgreSQL对于国人来说是十分简单的事情,因为我们有PostgreSQL中文的网站:http://www.pgsqldb.org/ 从那里可以了解到PostgreSQL很多历史和特长,并切可以在那里学习到好多使用技巧。
作者的操作平台是FreeBSD 4.8 stable,恰恰PostgreSQL和BSD是同出一门的,看看http://www.pgsqldb.org/postgres-faq.html 里关于PostgreSQL 的版权吧!所以安装起来特别顺利!
大家可以利用BSD的Ports 来安装。
FBSD# cd /usr/ports/databases/postgresql7
(如果没更新Ports 的话,这个PostgreSQL是7.3.2,更新后是7.3.3)
FBSD# make install
…..
片刻就安装完成。
但我更趋向于自己编译安装,可以定制目录的。
1、下载PostgreSQL包
FBSD# fetch ftp://ftp3.ca.postgresql.org/pub/source/v7.3.3/postgresql-7.3.3.tar.gz
(大家可以到 http://www.postgresql.org/mirrors-ftp.html 那里选择一个快的Mirror下载)
Receiving postgresql-7.3.3.tar.gz (11210071 bytes): 100% (ETA 00:00)
11210071 bytes transferred in 165.6 seconds (66.12 kBps)
FBSD# tar zxvf postgresql-7.3.3.tar.gz
FBSD# ls –lA
drwxr-xr-x 6 70 70 512 May 25 05:36 postgresql-7.3.3
-rw-r--r-- 1 root wheel 11210071 May 25 05:36 postgresql-7.3.3.tar.gz
FBSD# cd postgresql-7.3.3
FBSD# ./configure
(其实这的configure 可以加参数,但是我觉得它默认安装就已经满足了我初探要求了)
FBSD# gmake
….
All of PostgreSQL successfully made. Ready to install.
(make 成功)
FBSD# su (要有root的权限)
FBSD# gmake install
……
Please check the following URL for a listing of the current user-support
mailing lists:
http://www.ca.postgresql.org/users-lounge/index.html#maillist
All of the mailing lists are currently archived and viewable at:
http://archives.postgresql.org/
And, so that we have an idea of who is using what, please connect to the
following registration URL:
http://www.pgsql.com/register/submit.php
Thank you for choosing PostgreSQL, the most advanced open source database
engine.
(其实现在PostgreSQL已经安装完毕)
FBSD# pw useradd postgres -d /usr/local/pgsql/data
(为PostgreSQL 添加启动用户postgres ,各系统的添加可能不一样。)
FBSD# mkdir /usr/local/pgsql/data
(添加PostgreSQL的数据库目录)
FBSD# chown postgres /usr/local/pgsql/data
(将data 目录所属人改为postgres 的)
FBSD# su - postgres
(改变用户)
$
(变成普通用户后,状态符变成$了)
$ /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.
The database cluster will be initialized with locale C.
Fixing permissions on existing directory /usr/local/pgsql/data... ok
creating directory /usr/local/pgsql/data/base... ok
creating directory /usr/local/pgsql/data/global... ok
creating directory /usr/local/pgsql/data/pg_xlog... ok
creating directory /usr/local/pgsql/data/pg_clog... ok
creating template1 database in /usr/local/pgsql/data/base/1... ok
creating configuration files... ok
initializing pg_shadow... ok
enabling unlimited row size for system tables... ok
initializing pg_depend... ok
creating system views... ok
loading pg_description... ok
creating conversions... ok
setting privileges on built-in objects... ok
vacuuming database template1... ok
copying template1 to template0... ok
Success. You can now start the database server using:
/usr/local/pgsql/bin/postmaster -D /usr/local/pgsql/data
or
/usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start
$
(安装数据库)
$ cd /usr/local/pgsql/data
$ /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start
(启动PostgreSQL数据库)
$ /usr/local/pgsql/bin/createdb test
CREATE DATABASE
(建立数据库test)
2、使用
下面大家可以一步一步接触PostgreSQL了。
$ /usr/local/pgsql/bin/psql test
Welcome to psql 7.3.3, the PostgreSQL interactive terminal.
Type: \copyright for distribution terms
\h for help with SQL commands
\? for help on internal slash commands
\g or terminate with semicolon to execute query
\q to quit
test=#
(大家看到=#状态符了吗?现在你可以输入以下命令看看)
test=# SELECT version();
version
---------------------------------------------------------------------
PostgreSQL 7.3.3 on i386-unknown-freebsd4.8, compiled by GCC 2.95.4
(1 row)
(哈哈……安装调试完成!)
想help 吗?输入\?
想退出?输入\q
3、初步应用
大家觉得这样操作已经很兴奋了吗?毕竟已经能操作PostgreSQL!想不想像Mysql 那样,用PHP去连接呢?PostgreSQL也像Mysql 那样,拥有phpPgAdmin 这样的web管理软件。不过我们得先编译PHP把—with-pgsql 加入!
FBSD# ./configure --with-pgsl –with-apxs=/usr/local/apache/bin/apxs
(大家的编译可能不一样,因为我是用apache 的DSO去编译apache 的,说不定那天我再用Mysql 的时候,也会从新编译php ,这样就方便多了,不用重新编译apache)
FBSD# make
FBSD# make install
这个时候重启你的apache,当然要配置一下你的httpd.conf 文件,这个我就不在这里重复了。
FBSD# /usr/local/apache/bin/apachectl stop
FBSD# /usr/local/apache/bin/apachectl start
在apache 的DocumentRoot 目录下建立一个文件。我这里是/usr/local/apache/htdocs/
FBSD#vi /usr/local/apache/htdocs/phpinfo.php
<?php
phpinfo()
?>
然后安装一个PhpPgAdmin
phpPgAdmin 在Ports 里也有喔。呵,FreeBSD里的Ports 可真是锦囊啊!什么东西都有!不过我还是喜欢自己Download 一个Source Package回来使用的。
到 http://phppgadmin.sourceforge.net/ 下面去下载一个PhpPgAdmin 3.0
FBSD# fetch http://flow.dl.sourceforge.net/sourceforge/phppgadmin/phpPgAdmin-3.0.tar.gz
Receiving phpPgAdmin-3.0.tar.gz (349059 bytes): 100%
349059 bytes transferred in 4.6 seconds (73.43 kBps)
FBSD# tar zxvf phpPgAdmin-3.0.tar.gz -C /usr/local/apache/htdocs/
(将phpPgAdmin-3.2.tar.gz 解压到 /usr/local/apache/htdocs/下面去)
修改phpPgAdmin 的配置文件conf/config.inc.php
$conf['servers'][0]['desc'] = 'PostgreSQL'; // Display name for server
$conf['servers'][0]['host'] = '127.0.0.1'; // Hostname or IP address for server.
$conf['servers'][0]['port'] = 5432; // Database port on server
$conf['servers'][0]['defaultdb'] = 'test'; // Default database to connect to.
接着就要看 /usr/local/pgsql/data/pg_hba.conf 里面是否有
# TYPE DATABASE USER IP-ADDRESS IP-MASK METHOD
local all all trust
host all all 127.0.0.1 255.255.255.255 trust
这是开放127.0.0.1 可以访问。
好了,一切准备就绪,只等从启PostgreSQL了!
FBSD# su – postgres
$ cd /usr/local/pgsql/data
$ /usr/loca/pgsql/bin/pg_ctl stop –D /usr/local/pgsql/data
(停止数据库)
$ /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start -o -i
(重新启动数据库,要加参数-o -i 这是打开PostgreSQL的远程访问功能)
然后打开浏览器
输入 http://pgsql.kingisme.com/phpPgAdmin/index.php
登陆后的界面
4、小结
到此为止,我们已经把PostgreSQL装好了,至于更深入的应用,请大家查看PostgreSQL的手册和PHP连接PostgreSQL的部分。下面推荐几个关于PostgreSQL的站给大家学习。
http://www.postgresql.org/
postgresql的大本营
http://gborg.postgresql.org/
postgresql开发者网站
http://archives.postgresql.org/
收集有postgresql邮件列表
http://techdocs.postgresql.org/
非常多的技术文档,看域名就看得出来
http://www.pgsqldb.org/
postgresql的中文网站,提供有非常宝贵的中文版手册,站长是postgresql大牛
http://www.pgsql.com.tw/
台湾那边的一个讨论、推广postgresql站
最后希望大家能领略PostgreSQL的过人之处!!
文章的最后要感谢夜猫子对我在学PostgreSQL的帮助。