分享
 
 
 

PostgreSQL数据库初探

王朝mssql·作者佚名  2008-05-18
窄屏简体版  字體: |||超大  

在*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()

?>

[myimg]upload/pgsql1.jpg[/myimg]

然后安装一个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

[myimg]upload/pgsql2.jpg[/myimg]

登陆后的界面

[myimg]upload/pgsql3.jpg[/myimg]

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的帮助。

注:任何转载或摘抄请注明文章出处(中文FreeBSD用户组 http://www.cnfug.org)

注:任何转载或摘抄请注明文章出处(中文FreeBSD用户组 http://www.cnfug.org)

作者(译者)信息:

绝对蓝屏,CNFUG(http://www.cnfug.org)核心成员,你可以通过ihweb@cnfug.org来联系他,同时你也可以访问他的网站:http://www.kingisme.com

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有