Skip to content
PostgreSQL SQL/MED FDW for CouchDB (PostgreSQL 9.2+)
Branch: master
Clone or download
Pull request Compare This branch is 15 commits ahead of ZhengYang:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.


CouchDB FDW (beta) for PostgreSQL 9.1+  (Compatible PostgreSQL 9.2+)

This PostgreSQL extension implements a Foreign Data Wrapper (FDW) for
the CouchDB document-oriented database:

IMPORTANT: There're bugs in the existing version. I'm working on it and will
be releasing another version very soon.


To build the code, you need the yajl(Yet Another JSON Library) and libcurl installed 
on your system. 

You can checkout the yajl from GitHub:
download from:

libcurl C interface can be found here:

Once that's done, the extension can be built with:

PATH=/usr/local/pgsql91/bin/:$PATH make USE_PGXS=1 make
sudo PATH=/usr/local/pgsql91/bin/:$PATH make USE_PGXS=1 install

(assuming you have PostgreSQL 9.1 in /usr/local/pgsql91).

I've tested on Mac OS X 10.6 only, but other *nix's should also work.
I haven't tested on Windows, but the code should be good on MinGW.


- If there is no quals to pushdown, we get a list of '_id's to begin with,
  and then fetch whatever records still exist as we build the tuples.

- We can only pushdown '_id' (with or without '_rev') to CouchDB, which must use 
  the TEXTEQ operator.

- The top-level-attributes of a document can be mapped to columns in a
  foreign table.
- In case you want the map a column to the entire JOSN doc, use 
	columnname '_doc'
  in foreign table options (which means your remote couchdb shouldn't have
  a top-level-attribute called '_doc', otherwise there will be conficts).


The following parameters can be set on a CouchDB foreign server:

address:	The address or hostname of the CouchDB server.

port:		The port number on which the CouchDB server is listening.
     		Default: 5984

The following parameter can be set on a CouchDB foreign table:

database:	The name of the CouchDB database to query.
	  	Default: test

<column name>:	The column mapping to remote JSON attributes.
		If there is no column mapping specified, default is the origninal column name.
		Please note that '_doc' is reserved for mapping the entire JSON document.

The following parameter can be set on a user mapping for a CouchDB
foreign server:

username:	The username to authenticate to the CouchDB server with.
		Default: <none>
password:	The password to authenticate to the CouchDB server with.
		Default: <none>


* Initializing the CouchDB server using curl:

	- Create database:
		curl -X PUT http://localhost:5984/testdb
	- List databases:
		curl -X GET http://localhost:5984/_all_dbs
	- Create document:
		curl -X PUT http://localhost:5984/testdb/mydoc_1 -d "{\"title\": \"My first document\", \"content\": \"Hello World!\"}"
	- Create user:
		curl -HContent-Type:application/json -vXPUT --data-binary "{\"_id\": \"org.couchdb.user:testuser\",\"name\": \"testuser\",\"roles\": [],\"type\": \"user\",\"password\": \"secret\"}"

* Testing the extension:
	CREATE EXTENSION couchdb_fdw;
	--Then create a foreign server to connect to your CouchDB server:

	CREATE SERVER couchdb_server 
		OPTIONS (address '', port '5984');

	-- Create a foreign table:

	CREATE FOREIGN TABLE couchdb_table (key text, value text) 
		SERVER couchdb_server
		OPTIONS (database 'testdb', key '_id', value '_doc');

	--Create user mapping:

		SERVER couchdb_server
		OPTIONS (username 'testuser', password 'secret');	
	--And list documents...
	SELECT * FROM couchdb_table;

* Ouput gives:

"mydoc_1";"{"_id":"mydoc_1","_rev":"1-2fe116a139a166a7f85b85387327d4bc","title":"My first document","content":"Hello World!"}"

Zheng Yang
Ported to PostgreSQL 9.2+ Foreign Data Wrapper API
Gauthier Boaglio
gauthier.boaglio _4t_ gmail _D0t_ com
Windows installer:

You can’t perform that action at this time.