Fixed #12941 -- Added documentation for the connections dictionary. Thanks to atlithorn@gmail.com for the report, and Alex Gaynor for the original text.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@12709 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Russell Keith-Magee 2010-03-08 03:19:26 +00:00
parent abd0e96285
commit b50a35a669
2 changed files with 23 additions and 2 deletions

View File

@ -535,3 +535,15 @@ This example sets up two admin sites. On the first site, the
objects have an tabular inline showing books published by that objects have an tabular inline showing books published by that
publisher. The second site exposes just publishers, without the publisher. The second site exposes just publishers, without the
inlines. inlines.
Using raw cursors with multiple databases
=========================================
If you are using more than one database you can use
``django.db.connections`` to obtain the connection (and cursor) for a
specific database. ``django.db.connections`` is a dictionary-like
object that allows you to retrieve a specific connection using it's
alias::
from django.db import connections
cursor = connections['my_db_alias'].cursor()

View File

@ -196,8 +196,8 @@ In these cases, you can always access the database directly, routing around
the model layer entirely. the model layer entirely.
The object ``django.db.connection`` represents the The object ``django.db.connection`` represents the
current database connection, and ``django.db.transaction`` represents the default database connection, and ``django.db.transaction`` represents the
current database transaction. To use the database connection, call default database transaction. To use the database connection, call
``connection.cursor()`` to get a cursor object. Then, call ``connection.cursor()`` to get a cursor object. Then, call
``cursor.execute(sql, [params])`` to execute the SQL and ``cursor.fetchone()`` ``cursor.execute(sql, [params])`` to execute the SQL and ``cursor.fetchone()``
or ``cursor.fetchall()`` to return the resulting rows. After performing a data or ``cursor.fetchall()`` to return the resulting rows. After performing a data
@ -220,6 +220,15 @@ is required. For example::
return row return row
If you are using more than one database you can use
``django.db.connections`` to obtain the connection (and cursor) for a
specific database. ``django.db.connections`` is a dictionary-like
object that allows you to retrieve a specific connection using it's
alias::
from django.db import connections
cursor = connections['my_db_alias'].cursor()
.. _transactions-and-raw-sql: .. _transactions-and-raw-sql:
Transactions and raw SQL Transactions and raw SQL