看来,口对PostgreSQL 9.1现在包括hstore,但它仍然需要启用。正常安装并启动数据库。
sudo port install postgresql91 postgresql91-server
sudo mkdir -p /opt/local/var/db/postgresql91/defaultdb
sudo chown postgres:postgres /opt/local/var/db/postgresql91/defaultdb
sudo su postgres -c '/opt/local/lib/postgresql91/bin/initdb \
-D /opt/local/var/db/postgresql91/defaultdb'
sudo port load postgresql91-server
编辑:在另一台计算机安装也没有工作。 hstore没有安装基础(我可能试过其他解决方案)。所以做这个上面负载命令之前:
sudo port unload postgresql91-server # if you did load above
sudo port build postgresql91
port work postgresql91 # Gives you base dir for following command
cd /opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_ports_databases_postgresql91/postgresql91/work/postgresql-9.1.*/contrib/hstore
sudo make all
sudo make install clean
sudo port load postgresql91-server
要启用hstore扩展,数据库中的()你将使用hstore使用新的“创建扩展” SQL命令。如果将其安装到template1数据库中,则后来创建的所有数据库都将具有hstore扩展名。
psql template1 postgres
template1=# create extension hstore;
如果你只需要在一个特定的数据库扩展:
psql dbname dbuser
dbname=# create extension hstore;
create table a (id serial, data hstore);
NOTICE: CREATE TABLE will create implicit sequence "a_id_seq" for serial column "a.id"
CREATE TABLE
dbname=# insert into a(data) values('a=>1, b=>2');
INSERT 0 1
dbname=# SELECT * from a;
id | data
----+--------------------
1 | "a"=>"1", "b"=>"2"
(1 row)
Checkout @ rpkelly的答案在下面,它是最简单和最完整的。 – 2012-04-23 03:09:49