Getting started

This tutorial exposes key features of this library mainly through code
examples. For in-depth description of the modules, you’ll want to read
the API documentation.

If you have not installed couchdbkit yet, follow instructions on download page . Once you’ve done, you can write your first CouchDB document:

 import datetime

from couchdbkit import * class Greeting(Document): author = StringProperty() content = StringProperty() date = DateTimeProperty()

Store the submitted Greetings

Here is the code to save a greet on `Greeting` database. We also see how to create a database.

# server object server = Server() # create database db = server.get_or_create_db(“greeting”) # associate Greeting to the db Greeting.set_db(db) # create a new greet greet = Greeting( author=“Benoit”, content=“Welcome to couchdbkit world”, date=datetime.datetime.utcnow() ) # save it

Note: You can just use the method to save any Greeting object.

Your document `greet` is now in the `greetings` db. Each document is saved with a `doc_type` field that allow you to find easily each kind of document with the views. By default `doc_type` is the name of the class.

Now that you saved your document, you can update it: = u“Benoît Chesneau”

Here we updated the author name.

Dynamic properties

Mmm ok, but isn’t CouchDB storing documents schema less? Do you want to add a property ? Easy:

 greet.homepage = “”

Now you have just added an homepage property to the document.

Get all greetings

You first have to create a view and save it in the db. We will call it `greeting/all`. To do this we will use the loader system of couchdbkit that allows you to send views to couchdb.

Let’s create a folder that contains the design doc, and then the folder for the view. On unix :

 mkdir -p ~/Work/couchdbkit/example/_design/greeting/views/all

In this folder we edit a file `map.js`:

 function(doc) { 
   if (doc.doc_type == “Greeting”) 
    emit(doc._id, doc); 

On Textmate, you have:

couchdbkit textmate screen

A system will be provided to manage view creation and other things. As some noticed, this system works like couchapp.

Then we use `FileSystemDocsLoader` object to send the design document to CouchDB:

 from couchdbkit.designer import push

push(’/path/to/example/_design/greeting’, db)

The design doc is now in the `greetings` database and you can get all greets :

 greets = Greeting.view('greeting/all’)