Sembra che la porta per PostgreSQL 9.1 ora include hstore, ma ancora deve essere abilitato. Installa e avvia normalmente il database.
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
MODIFICA: l'installazione su un altro computer non ha funzionato bene. L'hstore non è stato installato con la base (avrei potuto renderlo disponibile provando altre soluzioni). Quindi, fare questo prima del comando di carico di cui sopra:
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
per abilitare l'estensione hstore, utilizzare il nuovo comando SQL "creare estensione" nel database (s) che si intende utilizzare hstore. Se lo si installa nel database template1, tutti i database creati in seguito avranno l'estensione hstore.
psql template1 postgres
template1=# create extension hstore;
Se avete solo bisogno l'estensione in un particolare database:
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)
Acquista la risposta di @ rpkelly qui sotto, è la più semplice e completa. –