设为首页 收藏本站
查看: 1256|回复: 0

[经验分享] PostgreSQL数据库初探

[复制链接]

尚未签到

发表于 2016-11-19 08:23:39 | 显示全部楼层 |阅读模式
来自:linux宝库
联系:linuxmine#gmail.com
分类:
  在*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
  <!--p&lt;b-->   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
本文来自:http://www.linuxpk.com/3345.html

本文转自
http://www.linuxpk.com/3345.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-302357-1-1.html 上篇帖子: 下载zip包版的Postgresql 下篇帖子: PostgreSQL 安装的一些问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表