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