Parece que el puerto para PostgreSQL 9.1 ahora incluye hstore, pero todavía necesita ser habilitado Instale e inicie la base de datos normalmente.
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
EDITAR: La instalación en otra computadora no funcionó tan bien. El hstore no se instaló con la base (puedo haberlo puesto a prueba con otras soluciones). Así que hacer esto antes de la orden de carga por encima:
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
Para habilitar la extensión hstore, utilizar el nuevo comando SQL "crear extensión" en la base de datos (s) que va a utilizar hstore. Si lo instala en la base de datos template1, todas las bases de datos creadas posteriormente tendrán la extensión hstore.
psql template1 postgres
template1=# create extension hstore;
Si sólo necesita la extensión en una base de datos concreta:
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)
La respuesta de Checkout @ rpkelly a continuación, es la más simple y completa. –