Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
95d7cdfd
Commit
95d7cdfd
authored
Sep 30, 2012
by
R David Murray
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix sqlite3 class markup.
parent
c820de5e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
213 additions
and
213 deletions
+213
-213
Doc/library/sqlite3.rst
Doc/library/sqlite3.rst
+213
-213
No files found.
Doc/library/sqlite3.rst
View file @
95d7cdfd
...
@@ -231,236 +231,236 @@ Connection Objects
...
@@ -231,236 +231,236 @@ Connection Objects
A SQLite database connection has the following attributes and methods:
A SQLite database connection has the following attributes and methods:
.. attribute:: Connection.
isolation_level
.. attribute::
isolation_level
Get or set the current isolation level. :const:`None` for autocommit mode or
Get or set the current isolation level. :const:`None` for autocommit mode or
one of "DEFERRED", "IMMEDIATE" or "EXCLUSIVE". See section
one of "DEFERRED", "IMMEDIATE" or "EXCLUSIVE". See section
:ref:`sqlite3-controlling-transactions` for a more detailed explanation.
:ref:`sqlite3-controlling-transactions` for a more detailed explanation.
.. method:: Connection.
cursor([cursorClass])
.. method::
cursor([cursorClass])
The cursor method accepts a single optional parameter *cursorClass*. If
The cursor method accepts a single optional parameter *cursorClass*. If
supplied, this must be a custom cursor class that extends
supplied, this must be a custom cursor class that extends
:class:`sqlite3.Cursor`.
:class:`sqlite3.Cursor`.
.. method:: Connection.
commit()
.. method::
commit()
This method commits the current transaction. If you don't call this method,
This method commits the current transaction. If you don't call this method,
anything you did since the last call to ``commit()`` is not visible from
anything you did since the last call to ``commit()`` is not visible from
other database connections. If you wonder why you don't see the data you've
other database connections. If you wonder why you don't see the data you've
written to the database, please check you didn't forget to call this method.
written to the database, please check you didn't forget to call this method.
.. method:: Connection.
rollback()
.. method::
rollback()
This method rolls back any changes to the database since the last call to
This method rolls back any changes to the database since the last call to
:meth:`commit`.
:meth:`commit`.
.. method:: Connection.
close()
.. method::
close()
This closes the database connection. Note that this does not automatically
This closes the database connection. Note that this does not automatically
call :meth:`commit`. If you just close your database connection without
call :meth:`commit`. If you just close your database connection without
calling :meth:`commit` first, your changes will be lost!
calling :meth:`commit` first, your changes will be lost!
.. method:: Connection.
execute(sql, [parameters])
.. method::
execute(sql, [parameters])
This is a nonstandard shortcut that creates an intermediate cursor object by
This is a nonstandard shortcut that creates an intermediate cursor object by
calling the cursor method, then calls the cursor's :meth:`execute
calling the cursor method, then calls the cursor's :meth:`execute
<Cursor.execute>` method with the parameters given.
<Cursor.execute>` method with the parameters given.
.. method:: Connection.
executemany(sql, [parameters])
.. method::
executemany(sql, [parameters])
This is a nonstandard shortcut that creates an intermediate cursor object by
This is a nonstandard shortcut that creates an intermediate cursor object by
calling the cursor method, then calls the cursor's :meth:`executemany
calling the cursor method, then calls the cursor's :meth:`executemany
<Cursor.executemany>` method with the parameters given.
<Cursor.executemany>` method with the parameters given.
.. method:: Connection.
executescript(sql_script)
.. method::
executescript(sql_script)
This is a nonstandard shortcut that creates an intermediate cursor object by
This is a nonstandard shortcut that creates an intermediate cursor object by
calling the cursor method, then calls the cursor's :meth:`executescript
calling the cursor method, then calls the cursor's :meth:`executescript
<Cursor.executescript>` method with the parameters given.
<Cursor.executescript>` method with the parameters given.
.. method:: Connection.
create_function(name, num_params, func)
.. method::
create_function(name, num_params, func)
Creates a user-defined function that you can later use from within SQL
Creates a user-defined function that you can later use from within SQL
statements under the function name *name*. *num_params* is the number of
statements under the function name *name*. *num_params* is the number of
parameters the function accepts, and *func* is a Python callable that is called
parameters the function accepts, and *func* is a Python callable that is called
as the SQL function.
as the SQL function.
The function can return any of the types supported by SQLite: unicode, str, int,
The function can return any of the types supported by SQLite: unicode, str, int,
long, float, buffer and None.
long, float, buffer and None.
Example:
Example:
.. literalinclude:: ../includes/sqlite3/md5func.py
.. literalinclude:: ../includes/sqlite3/md5func.py
.. method:: Connection.
create_aggregate(name, num_params, aggregate_class)
.. method::
create_aggregate(name, num_params, aggregate_class)
Creates a user-defined aggregate function.
Creates a user-defined aggregate function.
The aggregate class must implement a ``step`` method, which accepts the number
The aggregate class must implement a ``step`` method, which accepts the number
of parameters *num_params*, and a ``finalize`` method which will return the
of parameters *num_params*, and a ``finalize`` method which will return the
final result of the aggregate.
final result of the aggregate.
The ``finalize`` method can return any of the types supported by SQLite:
The ``finalize`` method can return any of the types supported by SQLite:
unicode, str, int, long, float, buffer and None.
unicode, str, int, long, float, buffer and None.
Example:
Example:
.. literalinclude:: ../includes/sqlite3/mysumaggr.py
.. literalinclude:: ../includes/sqlite3/mysumaggr.py
.. method:: Connection.
create_collation(name, callable)
.. method::
create_collation(name, callable)
Creates a collation with the specified *name* and *callable*. The callable will
Creates a collation with the specified *name* and *callable*. The callable will
be passed two string arguments. It should return -1 if the first is ordered
be passed two string arguments. It should return -1 if the first is ordered
lower than the second, 0 if they are ordered equal and 1 if the first is ordered
lower than the second, 0 if they are ordered equal and 1 if the first is ordered
higher than the second. Note that this controls sorting (ORDER BY in SQL) so
higher than the second. Note that this controls sorting (ORDER BY in SQL) so
your comparisons don't affect other SQL operations.
your comparisons don't affect other SQL operations.
Note that the callable will get its parameters as Python bytestrings, which will
Note that the callable will get its parameters as Python bytestrings, which will
normally be encoded in UTF-8.
normally be encoded in UTF-8.
The following example shows a custom collation that sorts "the wrong way":
The following example shows a custom collation that sorts "the wrong way":
.. literalinclude:: ../includes/sqlite3/collation_reverse.py
.. literalinclude:: ../includes/sqlite3/collation_reverse.py
To remove a collation, call ``create_collation`` with None as callable::
To remove a collation, call ``create_collation`` with None as callable::
con.create_collation("reverse", None)
con.create_collation("reverse", None)
.. method:: Connection.
interrupt()
.. method::
interrupt()
You can call this method from a different thread to abort any queries that might
You can call this method from a different thread to abort any queries that might
be executing on the connection. The query will then abort and the caller will
be executing on the connection. The query will then abort and the caller will
get an exception.
get an exception.
.. method:: Connection.
set_authorizer(authorizer_callback)
.. method::
set_authorizer(authorizer_callback)
This routine registers a callback. The callback is invoked for each attempt to
This routine registers a callback. The callback is invoked for each attempt to
access a column of a table in the database. The callback should return
access a column of a table in the database. The callback should return
:const:`SQLITE_OK` if access is allowed, :const:`SQLITE_DENY` if the entire SQL
:const:`SQLITE_OK` if access is allowed, :const:`SQLITE_DENY` if the entire SQL
statement should be aborted with an error and :const:`SQLITE_IGNORE` if the
statement should be aborted with an error and :const:`SQLITE_IGNORE` if the
column should be treated as a NULL value. These constants are available in the
column should be treated as a NULL value. These constants are available in the
:mod:`sqlite3` module.
:mod:`sqlite3` module.
The first argument to the callback signifies what kind of operation is to be
The first argument to the callback signifies what kind of operation is to be
authorized. The second and third argument will be arguments or :const:`None`
authorized. The second and third argument will be arguments or :const:`None`
depending on the first argument. The 4th argument is the name of the database
depending on the first argument. The 4th argument is the name of the database
("main", "temp", etc.) if applicable. The 5th argument is the name of the
("main", "temp", etc.) if applicable. The 5th argument is the name of the
inner-most trigger or view that is responsible for the access attempt or
inner-most trigger or view that is responsible for the access attempt or
:const:`None` if this access attempt is directly from input SQL code.
:const:`None` if this access attempt is directly from input SQL code.
Please consult the SQLite documentation about the possible values for the first
Please consult the SQLite documentation about the possible values for the first
argument and the meaning of the second and third argument depending on the first
argument and the meaning of the second and third argument depending on the first
one. All necessary constants are available in the :mod:`sqlite3` module.
one. All necessary constants are available in the :mod:`sqlite3` module.
.. method:: Connection.
set_progress_handler(handler, n)
.. method::
set_progress_handler(handler, n)
This routine registers a callback. The callback is invoked for every *n*
This routine registers a callback. The callback is invoked for every *n*
instructions of the SQLite virtual machine. This is useful if you want to
instructions of the SQLite virtual machine. This is useful if you want to
get called from SQLite during long-running operations, for example to update
get called from SQLite during long-running operations, for example to update
a GUI.
a GUI.
If you want to clear any previously installed progress handler, call the
If you want to clear any previously installed progress handler, call the
method with :const:`None` for *handler*.
method with :const:`None` for *handler*.
.. versionadded:: 2.6
.. versionadded:: 2.6
.. method:: Connection.
enable_load_extension(enabled)
.. method::
enable_load_extension(enabled)
This routine allows/disallows the SQLite engine to load SQLite extensions
This routine allows/disallows the SQLite engine to load SQLite extensions
from shared libraries. SQLite extensions can define new functions,
from shared libraries. SQLite extensions can define new functions,
aggregates or whole new virtual table implementations. One well-known
aggregates or whole new virtual table implementations. One well-known
extension is the fulltext-search extension distributed with SQLite.
extension is the fulltext-search extension distributed with SQLite.
Loadable extensions are disabled by default. See [#f1]_.
Loadable extensions are disabled by default. See [#f1]_.
.. versionadded:: 2.7
.. versionadded:: 2.7
.. literalinclude:: ../includes/sqlite3/load_extension.py
.. literalinclude:: ../includes/sqlite3/load_extension.py
.. method:: Connection.
load_extension(path)
.. method::
load_extension(path)
This routine loads a SQLite extension from a shared library. You have to
This routine loads a SQLite extension from a shared library. You have to
enable extension loading with :meth:`enable_load_extension` before you can
enable extension loading with :meth:`enable_load_extension` before you can
use this routine.
use this routine.
Loadable extensions are disabled by default. See [#f1]_.
Loadable extensions are disabled by default. See [#f1]_.
.. versionadded:: 2.7
.. versionadded:: 2.7
.. attribute:: Connection.
row_factory
.. attribute::
row_factory
You can change this attribute to a callable that accepts the cursor and the
You can change this attribute to a callable that accepts the cursor and the
original row as a tuple and will return the real result row. This way, you can
original row as a tuple and will return the real result row. This way, you can
implement more advanced ways of returning results, such as returning an object
implement more advanced ways of returning results, such as returning an object
that can also access columns by name.
that can also access columns by name.
Example:
Example:
.. literalinclude:: ../includes/sqlite3/row_factory.py
.. literalinclude:: ../includes/sqlite3/row_factory.py
If returning a tuple doesn't suffice and you want name-based access to
If returning a tuple doesn't suffice and you want name-based access to
columns, you should consider setting :attr:`row_factory` to the
columns, you should consider setting :attr:`row_factory` to the
highly-optimized :class:`sqlite3.Row` type. :class:`Row` provides both
highly-optimized :class:`sqlite3.Row` type. :class:`Row` provides both
index-based and case-insensitive name-based access to columns with almost no
index-based and case-insensitive name-based access to columns with almost no
memory overhead. It will probably be better than your own custom
memory overhead. It will probably be better than your own custom
dictionary-based approach or even a db_row based solution.
dictionary-based approach or even a db_row based solution.
.. XXX what's a db_row-based solution?
.. XXX what's a db_row-based solution?
.. attribute:: Connection.
text_factory
.. attribute::
text_factory
Using this attribute you can control what objects are returned for the ``TEXT``
Using this attribute you can control what objects are returned for the ``TEXT``
data type. By default, this attribute is set to :class:`unicode` and the
data type. By default, this attribute is set to :class:`unicode` and the
:mod:`sqlite3` module will return Unicode objects for ``TEXT``. If you want to
:mod:`sqlite3` module will return Unicode objects for ``TEXT``. If you want to
return bytestrings instead, you can set it to :class:`str`.
return bytestrings instead, you can set it to :class:`str`.
For efficiency reasons, there's also a way to return Unicode objects only for
For efficiency reasons, there's also a way to return Unicode objects only for
non-ASCII data, and bytestrings otherwise. To activate it, set this attribute to
non-ASCII data, and bytestrings otherwise. To activate it, set this attribute to
:const:`sqlite3.OptimizedUnicode`.
:const:`sqlite3.OptimizedUnicode`.
You can also set it to any other callable that accepts a single bytestring
You can also set it to any other callable that accepts a single bytestring
parameter and returns the resulting object.
parameter and returns the resulting object.
See the following example code for illustration:
See the following example code for illustration:
.. literalinclude:: ../includes/sqlite3/text_factory.py
.. literalinclude:: ../includes/sqlite3/text_factory.py
.. attribute:: Connection.
total_changes
.. attribute::
total_changes
Returns the total number of database rows that have been modified, inserted, or
Returns the total number of database rows that have been modified, inserted, or
deleted since the database connection was opened.
deleted since the database connection was opened.
.. attribute:: Connection.
iterdump
.. attribute::
iterdump
Returns an iterator to dump the database in an SQL text format. Useful when
Returns an iterator to dump the database in an SQL text format. Useful when
saving an in-memory database for later restoration. This function provides
saving an in-memory database for later restoration. This function provides
the same capabilities as the :kbd:`.dump` command in the :program:`sqlite3`
the same capabilities as the :kbd:`.dump` command in the :program:`sqlite3`
shell.
shell.
.. versionadded:: 2.6
.. versionadded:: 2.6
Example::
Example::
# Convert file existing_db.db to SQL dump file dump.sql
# Convert file existing_db.db to SQL dump file dump.sql
import sqlite3, os
import sqlite3, os
con = sqlite3.connect('existing_db.db')
con = sqlite3.connect('existing_db.db')
with open('dump.sql', 'w') as f:
with open('dump.sql', 'w') as f:
for line in con.iterdump():
for line in con.iterdump():
f.write('%s\n' % line)
f.write('%s\n' % line)
.. _sqlite3-cursor-objects:
.. _sqlite3-cursor-objects:
...
@@ -472,110 +472,110 @@ Cursor Objects
...
@@ -472,110 +472,110 @@ Cursor Objects
A :class:`Cursor` instance has the following attributes and methods.
A :class:`Cursor` instance has the following attributes and methods.
.. method:: Cursor.
execute(sql, [parameters])
.. method::
execute(sql, [parameters])
Executes an SQL statement. The SQL statement may be parameterized (i. e.
Executes an SQL statement. The SQL statement may be parameterized (i. e.
placeholders instead of SQL literals). The :mod:`sqlite3` module supports two
placeholders instead of SQL literals). The :mod:`sqlite3` module supports two
kinds of placeholders: question marks (qmark style) and named placeholders
kinds of placeholders: question marks (qmark style) and named placeholders
(named style).
(named style).
Here's an example of both styles:
Here's an example of both styles:
.. literalinclude:: ../includes/sqlite3/execute_1.py
.. literalinclude:: ../includes/sqlite3/execute_1.py
:meth:`execute` will only execute a single SQL statement. If you try to execute
:meth:`execute` will only execute a single SQL statement. If you try to execute
more than one statement with it, it will raise a Warning. Use
more than one statement with it, it will raise a Warning. Use
:meth:`executescript` if you want to execute multiple SQL statements with one
:meth:`executescript` if you want to execute multiple SQL statements with one
call.
call.
.. method:: Cursor.
executemany(sql, seq_of_parameters)
.. method::
executemany(sql, seq_of_parameters)
Executes an SQL command against all parameter sequences or mappings found in
Executes an SQL command against all parameter sequences or mappings found in
the sequence *sql*. The :mod:`sqlite3` module also allows using an
the sequence *sql*. The :mod:`sqlite3` module also allows using an
:term:`iterator` yielding parameters instead of a sequence.
:term:`iterator` yielding parameters instead of a sequence.
.. literalinclude:: ../includes/sqlite3/executemany_1.py
.. literalinclude:: ../includes/sqlite3/executemany_1.py
Here's a shorter example using a :term:`generator`:
Here's a shorter example using a :term:`generator`:
.. literalinclude:: ../includes/sqlite3/executemany_2.py
.. literalinclude:: ../includes/sqlite3/executemany_2.py
.. method:: Cursor.
executescript(sql_script)
.. method::
executescript(sql_script)
This is a nonstandard convenience method for executing multiple SQL statements
This is a nonstandard convenience method for executing multiple SQL statements
at once. It issues a ``COMMIT`` statement first, then executes the SQL script it
at once. It issues a ``COMMIT`` statement first, then executes the SQL script it
gets as a parameter.
gets as a parameter.
*sql_script* can be a bytestring or a Unicode string.
*sql_script* can be a bytestring or a Unicode string.
Example:
Example:
.. literalinclude:: ../includes/sqlite3/executescript.py
.. literalinclude:: ../includes/sqlite3/executescript.py
.. method:: Cursor.
fetchone()
.. method::
fetchone()
Fetches the next row of a query result set, returning a single sequence,
Fetches the next row of a query result set, returning a single sequence,
or :const:`None` when no more data is available.
or :const:`None` when no more data is available.
.. method:: Cursor.
fetchmany([size=cursor.arraysize])
.. method::
fetchmany([size=cursor.arraysize])
Fetches the next set of rows of a query result, returning a list. An empty
Fetches the next set of rows of a query result, returning a list. An empty
list is returned when no more rows are available.
list is returned when no more rows are available.
The number of rows to fetch per call is specified by the *size* parameter.
The number of rows to fetch per call is specified by the *size* parameter.
If it is not given, the cursor's arraysize determines the number of rows
If it is not given, the cursor's arraysize determines the number of rows
to be fetched. The method should try to fetch as many rows as indicated by
to be fetched. The method should try to fetch as many rows as indicated by
the size parameter. If this is not possible due to the specified number of
the size parameter. If this is not possible due to the specified number of
rows not being available, fewer rows may be returned.
rows not being available, fewer rows may be returned.
Note there are performance considerations involved with the *size* parameter.
Note there are performance considerations involved with the *size* parameter.
For optimal performance, it is usually best to use the arraysize attribute.
For optimal performance, it is usually best to use the arraysize attribute.
If the *size* parameter is used, then it is best for it to retain the same
If the *size* parameter is used, then it is best for it to retain the same
value from one :meth:`fetchmany` call to the next.
value from one :meth:`fetchmany` call to the next.
.. method:: Cursor.
fetchall()
.. method::
fetchall()
Fetches all (remaining) rows of a query result, returning a list. Note that
Fetches all (remaining) rows of a query result, returning a list. Note that
the cursor's arraysize attribute can affect the performance of this operation.
the cursor's arraysize attribute can affect the performance of this operation.
An empty list is returned when no rows are available.
An empty list is returned when no rows are available.
.. attribute:: Cursor.
rowcount
.. attribute::
rowcount
Although the :class:`Cursor` class of the :mod:`sqlite3` module implements this
Although the :class:`Cursor` class of the :mod:`sqlite3` module implements this
attribute, the database engine's own support for the determination of "rows
attribute, the database engine's own support for the determination of "rows
affected"/"rows selected" is quirky.
affected"/"rows selected" is quirky.
For :meth:`executemany` statements, the number of modifications are summed up
For :meth:`executemany` statements, the number of modifications are summed up
into :attr:`rowcount`.
into :attr:`rowcount`.
As required by the Python DB API Spec, the :attr:`rowcount` attribute "is -1 in
As required by the Python DB API Spec, the :attr:`rowcount` attribute "is -1 in
case no ``executeXX()`` has been performed on the cursor or the rowcount of the
case no ``executeXX()`` has been performed on the cursor or the rowcount of the
last operation is not determinable by the interface". This includes ``SELECT``
last operation is not determinable by the interface". This includes ``SELECT``
statements because we cannot determine the number of rows a query produced
statements because we cannot determine the number of rows a query produced
until all rows were fetched.
until all rows were fetched.
With SQLite versions before 3.6.5, :attr:`rowcount` is set to 0 if
With SQLite versions before 3.6.5, :attr:`rowcount` is set to 0 if
you make a ``DELETE FROM table`` without any condition.
you make a ``DELETE FROM table`` without any condition.
.. attribute:: Cursor.
lastrowid
.. attribute::
lastrowid
This read-only attribute provides the rowid of the last modified row. It is
This read-only attribute provides the rowid of the last modified row. It is
only set if you issued a ``INSERT`` statement using the :meth:`execute`
only set if you issued a ``INSERT`` statement using the :meth:`execute`
method. For operations other than ``INSERT`` or when :meth:`executemany` is
method. For operations other than ``INSERT`` or when :meth:`executemany` is
called, :attr:`lastrowid` is set to :const:`None`.
called, :attr:`lastrowid` is set to :const:`None`.
.. attribute:: Cursor.
description
.. attribute::
description
This read-only attribute provides the column names of the last query. To
This read-only attribute provides the column names of the last query. To
remain compatible with the Python DB API, it returns a 7-tuple for each
remain compatible with the Python DB API, it returns a 7-tuple for each
column where the last six items of each tuple are :const:`None`.
column where the last six items of each tuple are :const:`None`.
It is set for ``SELECT`` statements without any matching rows as well.
It is set for ``SELECT`` statements without any matching rows as well.
.. _sqlite3-row-objects:
.. _sqlite3-row-objects:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment