来自: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
<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
分享到:
相关推荐
PostgreSQL是一种开源的对象关系数据库系统,由于其性能优越、可靠性高、功能强大,在全球范围内得到了广泛的应用。然而,传统的流复制数据库集群架构尽管提供了高可用性和读写分离等优势,但同时也存在一些缺陷,...
陈刚-平安科技-PostgreSQL数据库源码浅析.pdf 王鹏冲-平安科技-从ACID的D看三种主流关系型数据库.pdf 陈旭-平安壹钱包-大数据实时流计算风云榜.pdf 王青松-飞象数据-实现PostgreSQL逻辑复制实战.pdf 德哥-...
《PostgreSQL与MySQL的比较研究初探》这篇文章探讨了两种主流的开源数据库系统——PostgreSQL和MySQL之间的差异,主要从标识列、字符串类型、JSP/Servlet开发中的中文处理、多平台支持和性能等方面进行了综合分析。...
在PostgreSQL中,查询效率是数据库性能的关键因素。优化查询速度可以显著提升系统的整体性能,尤其是在处理大量数据时。查询效率的计算涉及到一系列参数和算法,这些参数可以在`postgresql.conf`配置文件中调整,也...
文档提及了ODI在Oracle环境下的部署与运行,包括操作系统(Windows XP)、数据库(Oracle XE10G和PostgreSQL 9.0.2)、WebLogic Server (WLS) 10.3.3以及ODI自身版本(11.1.1.3)的兼容性测试。这表明ODI 11G不仅...
在数据库的设计方面,需要选择合适的数据库管理系统,例如 MySQL、 PostgreSQL 等,并对数据库进行优化设置,以提高数据库的性能。 三、负载均衡技术在高性能高并发服务器架构中的应用 负载均衡技术是指将用户请求...
- **PostgreSQL**:一个对象关系型数据库管理系统(ORDBMS),开源且具有高度的稳定性和性能。它在GIS领域表现突出,适用于需要高性能分析处理的场景,如电信和金融服务领域。 - **SQLite**:自2000年起,SQLite作为...
对于数据库操作,SpringBoot提供了对多种数据库的支持,包括MySQL、PostgreSQL等。在pom.xml或build.gradle中添加对应的数据库驱动依赖,并在application.properties中配置数据库连接信息。使用Data JPA时,可以通过...
- **PostgreSQL 配置**:教授如何在 NanoPi M3 上安装并配置 PostgreSQL 数据库。 - **数据库管理**:介绍如何管理和维护数据库中的数据。 #### 7. 手机作为显示器 - **实现方法**:展示如何通过 Wi-Fi 将手机作为...
3. 数据库:MySQL或PostgreSQL作为数据存储,用于保存用户信息、菜品数据、订单记录等。 4. API:可能使用RESTful API设计原则,实现前后端分离,提高系统可扩展性。 二、系统功能模块 1. 用户管理:用户注册、...
Django支持多种数据库,如SQLite、MySQL、PostgreSQL等。通过`settings.py`配置数据库连接,可以使用ORM(对象关系映射)进行数据操作。 12. **测试** Django提供了一套强大的测试框架,允许开发者编写单元测试和...
数据库方面,MySQL或者PostgreSQL可能是常用的数据库选择,用于存储学生、课程等相关数据。 此外,前端界面可能使用HTML、CSS和JavaScript进行开发,配合Bootstrap或Vue.js等前端框架,以实现响应式布局和动态交互...
6. **数据库集成**:Spring Boot提供了对多种数据库的支持,如MySQL、PostgreSQL等,通常会通过JPA或MyBatis等持久层框架进行数据操作。 7. **依赖管理**:在`pom.xml`或`build.gradle`中,可以看到项目的依赖管理...
5. **数据库交互**:为了存储和检索问题及答案,"simple_quiz"可能使用了SQLite、MySQL或PostgreSQL等数据库。Python的SQLAlchemy库是一个常用的ORM(对象关系映射)工具,它简化了数据库操作,使得开发者可以用...
2. **数据存储**:系统需要存储课程、学生、教师等信息,这通常通过关系型数据库如MySQL或PostgreSQL实现。Java的JDBC(Java Database Connectivity)API可以用来连接和操作数据库。 3. **业务逻辑**:选课过程涉及...
当然,如果需要支持多用户或者大数据量,也可能选择了MySQL或PostgreSQL这样的关系型数据库。 博客文章的创建、编辑和展示,通常会涉及到HTML、CSS和JavaScript的使用。HTML用于构建网页的基本结构,CSS负责样式...
Django支持多种数据库,包括SQLite(默认)、MySQL、PostgreSQL等。在`settings.py`文件中配置数据库连接,然后运行`python manage.py migrate`命令来同步数据库模型。 最后,我们可以通过`python manage.py ...
在数据库层面,项目可能采用了关系型数据库如MySQL或PostgreSQL,用于存储图书信息(如书名、作者、出版社等)、用户信息(如用户名、密码、借阅历史等)以及借阅状态(如借出、归还、逾期等)。数据库设计应遵循...