The response to a bulk creation / update now looks like this
[
    {"id": "0", "rev": "3682408536"},
    {"id": "1", "rev": "3206753266"},
    {"id": "2", "error": "conflict", "reason": "Document update conflict."}
]
The database file format has changed. CouchDB itself does yet not provide any tools for migrating your data. In the meantime, you can use third-party scripts to deal with the migration, such as the dump/load tools that come with the development version (trunk) of couchdb-python.
The view query API has been changed: count has become limit. This is a better description of what the parameter does, and should be a simple update in any client code.
The view URLs have been moved to design document resources. This means that paths that used to be like:
http://hostname:5984/mydb/_view/designname/viewname?limit=10
will now look like:
http://hostname:5984/mydb/_design/designname/_view/viewname?limit=10.
See the REST, Hypermedia, and CouchApps thread on dev for details.
Names of attachments are no longer allowed to start with an underscore.
Some refinements have been made to error handling. CouchDB will send 400 instead of 500 on invalid query parameters. Most notably, document update conflicts now respond with 409 Conflict instead of 412 Precondition Failed. The error code for when attempting to create a database that already exists is now 412 instead of 409.
CouchDB 0.9 changes sections and configuration variable names in configuration files. Old .ini files won’t work. Also note that CouchDB now ships with two .ini files where 0.8 used couch.ini there are now default.ini and local.ini. default.ini contains CouchDB’s standard configuration values. local.ini is meant for local changes. local.ini is not overwritten on CouchDB updates, so your edits are safe. In addition, the new runtime configuration system persists changes to the configuration in local.ini.