容我开头啰嗦一下。一直以来,我和 MySQL 这位久经考验的老朋友合作愉快。但自从了解了一点 PostgreSQL 后, 对其丰富的功能特性就十分着迷。比如字段类型原生支持 json, xml 和 array。跟 MySQL 比起来,感觉 PostgreSQL 更高级一些。
安装brew
官方文档:
http://mxcl.github.com/homebrew/
先安装Git,打开一个shell:
1
2
3
4
5
6
7
|
cd /usr/local sudo mkdir homebrew curl -L https: //github .com /mxcl/homebrew/tarball/master | sudo tar xz --strip 1 -C homebrew cd homebrew /bin . /brew - v file brew cat brew | moresudo . /brew update |
如果“brew update”命令执行出错,请确保文件夹/usr/local的所有者权限是你本人而不是root:
1
|
sudo chown $USER /usr/localbrew updat |
在".bash_profile"中更新路径配置
(如果~下没有文件".bash_profile" 请执行: touch '.bash_profile' )
1
|
vim '.bash_profile' |
加入
1
|
export PATH=$PATH:/usr/local/homebrew/bin |
之后可以直接执行brew(不用./brew)
如果有了Git可以这样安装(未测试)
1
2
3
4
|
git clone https: //github .com /mxcl/homebrew .git cd homebrew /bin cd homebrew /bin . /brew - v |
安装测试
1
2
3
|
. /brew install wget . /brew uninstall wget . /brew searc /apache */ |
安装PostgreSQL
使用 brew 一句搞定。
1
|
brew install postgres |
初始化数据库
1
|
initdb /usr/local/var/postgres |
启动或停止数据库
启动服务:
1
|
pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server .log start |
停止服务:
1
|
pg_ctl -D /usr/local/var/postgres stop -s -m fast |
如果先嫌麻烦,可以加入开机自动启动
1
|
ln -sfv /usr/local/opt/postgresql/ *.plist ~ /Library/LaunchAgents |
常用操作
1.创建一个 PostgreSQL 用户
1
2
3
|
createuser username -P #Enter password for new role: #Enter it again: |
上面的 username 是用户名,回车输入 2 次用户密码后即用户创建完成。更多用户创建信息可以 "createuser --help" 查看。
2.创建数据库
1
|
createdb dbname -O username -E UTF8 -e |
上面创建了一个名为 dbname 的数据库,并指定 username 为改数据库的拥有者(owner),数据库的编码(encoding)是 UTF8,参数 "-e" 是指把数据库执行操作的命令显示出来。
更多数据库创建信息可以 "createdb --help" 查看。
3.连接数据库
1
|
psql -U username -d dbname -h 127.0.0.1 |
心得体会
还在学习中,大致觉得跟 MySQL 区别不大,都是执行标准的 SQL 语句。目前就发现 limit 语句跟 MySQL 有区别。比如 MySQL 中取前 10 条记录:
1
|
select * from table limit 0, 10 |
而在 PostgreSQL 中则是:
1
|
select * from table limit 10 offset 0 |
这样一看,倒觉得 PostgreSQL 的看起来更清晰一些。MySQL 中的 offset 是可选项,熟悉了以后用起来无妨,刚开始学时就很容易会分不清 offset 和 limit 值的位置。