sqlite3 --- SQLite 資料庫的 DB-API 2.0 介面¶
原始碼:Lib/sqlite3/
SQLite is a C library that provides a lightweight disk-based database that doesn't require a separate server process and allows accessing the database using a nonstandard variant of the SQL query language. Some applications can use SQLite for internal data storage. It's also possible to prototype an application using SQLite and then port the code to a larger database such as PostgreSQL or Oracle.
The sqlite3 module was written by Gerhard Häring. It provides an SQL interface
compliant with the DB-API 2.0 specification described by PEP 249, and
requires the third-party SQLite library.
This is an optional module. If it is missing from your copy of CPython, look for documentation from your distributor (that is, whoever provided Python to you). If you are the distributor, see 可選模組的需求.
此文件包含四個主要章節:
教學 教導如何使用
sqlite3模組。Reference 描述此模組定義的類別與函式。
How-to guides 詳細說明如何處理特定工作。
解釋 深入提供交易 (transaction) 控制的背景。
也參考
- https://www.sqlite.org
The SQLite web page; the documentation describes the syntax and the available data types for the supported SQL dialect.
- https://www.w3schools.com/sql/
Tutorial, reference and examples for learning SQL syntax.
- PEP 249 - 資料庫 API 規格 2.0
PEP 由 Marc-André Lemburg 撰寫。
教學¶
In this tutorial, you will create a database of Monty Python movies
using basic sqlite3 functionality.
It assumes a fundamental understanding of database concepts,
including cursors and transactions.
First, we need to create a new database and open
a database connection to allow sqlite3 to work with it.
Call sqlite3.connect() to create a connection to
the database tutorial.db in the current working directory,
implicitly creating it if it does not exist:
import sqlite3
con = sqlite3.connect("tutorial.db")
The returned Connection object con
represents the connection to the on-disk database.
In order to execute SQL statements and fetch results from SQL queries,
we will need to use a database cursor.
Call con.cursor() to create the Cursor:
cur = con.cursor()
Now that we've got a database connection and a cursor,
we can create a database table movie with columns for title,
release year, and review score.
For simplicity, we can just use column names in the table declaration --
thanks to the flexible typing feature of SQLite,
specifying the data types is optional.
Execute the CREATE TABLE statement
by calling cur.execute(...):
cur.execute("CREATE TABLE movie(title, year, score)")
We can verify that the new table has been created by querying
the sqlite_master table built-in to SQLite,
which should now contain an entry for the movie table definition
(see The Schema Table for details).
Execute that query by calling cur.execute(...),
assign the result to res,
and call res.fetchone() to fetch the resulting row:
>>> res = cur.execute("SELECT name FROM sqlite_master")
>>> res.fetchone()
('movie',)
We can see that the table has been created,
as the query returns a tuple containing the table's name.
If we query sqlite_master for a non-existent table spam,
res.fetchone() will return None:
>>> res = cur.execute("SELECT name FROM sqlite_master WHERE name='spam'")
>>> res.fetchone() is None
True
Now, add two rows of data supplied as SQL literals
by executing an INSERT statement,
once again by calling cur.execute(...):
cur.execute("""
INSERT INTO movie VALUES
('Monty Python and the Holy Grail', 1975, 8.2),
('And Now for Something Completely Different', 1971, 7.5)
""")
The INSERT statement implicitly opens a transaction,
which needs to be committed before changes are saved in the database
(see Transaction control for details).
Call con.commit() on the connection object
to commit the transaction:
con.commit()
We can verify that the data was inserted correctly
by executing a SELECT query.
Use the now-familiar cur.execute(...) to
assign the result to res,
and call res.fetchall() to return all resulting rows:
>>> res = cur.execute("SELECT score FROM movie")
>>> res.fetchall()
[(8.2,), (7.5,)]
The result is a list of two tuples, one per row,
each containing that row's score value.
Now, insert three more rows by calling
cur.executemany(...):
data = [
("Monty Python Live at the Hollywood Bowl", 1982, 7.9),
("Monty Python's The Meaning of Life", 1983, 7.5),
("Monty Python's Life of Brian", 1979, 8.0),
]
cur.executemany("INSERT INTO movie VALUES(?, ?, ?)", data)
con.commit() # Remember to commit the transaction after executing INSERT.
Notice that ? placeholders are used to bind data to the query.
Always use placeholders instead of string formatting
to bind Python values to SQL statements,
to avoid SQL injection attacks
(see How to use placeholders to bind values in SQL queries for more details).
We can verify that the new rows were inserted
by executing a SELECT query,
this time iterating over the results of the query:
>>> for row in cur.execute("SELECT year, title FROM movie ORDER BY year"):
... print(row)
(1971, 'And Now for Something Completely Different')
(1975, 'Monty Python and the Holy Grail')
(1979, "Monty Python's Life of Brian")
(1982, 'Monty Python Live at the Hollywood Bowl')
(1983, "Monty Python's The Meaning of Life")
Each row is a two-item tuple of (year, title),
matching the columns selected in the query.
Finally, verify that the database has been written to disk
by calling con.close()
to close the existing connection, opening a new one,
creating a new cursor, then querying the database:
>>> con.close()
>>> new_con = sqlite3.connect("tutorial.db")
>>> new_cur = new_con.cursor()
>>> res = new_cur.execute("SELECT title, year FROM movie ORDER BY score DESC")
>>> title, year = res.fetchone()
>>> print(f'The highest scoring Monty Python movie is {title!r}, released in {year}')
The highest scoring Monty Python movie is 'Monty Python and the Holy Grail', released in 1975
>>> new_con.close()
You've now created an SQLite database using the sqlite3 module,
inserted data and retrieved values from it in multiple ways.
也參考
進一步參考 How-to guides:
解釋 for in-depth background on transaction control.
Reference¶
Module functions¶
- sqlite3.connect(database, timeout=5.0, detect_types=0, isolation_level='DEFERRED', check_same_thread=True, factory=sqlite3.Connection, cached_statements=128, uri=False, *, autocommit=sqlite3.LEGACY_TRANSACTION_CONTROL)¶
Open a connection to an SQLite database.
- 參數:
database (path-like object) -- The path to the database file to be opened. You can pass
":memory:"to create an SQLite database existing only in memory, and open a connection to it.timeout (float) -- How many seconds the connection should wait before raising an
OperationalErrorwhen a table is locked. If another connection opens a transaction to modify a table, that table will be locked until the transaction is committed. Default five seconds.detect_types (int) -- Control whether and how data types not natively supported by SQLite are looked up to be converted to Python types, using the converters registered with
register_converter(). Set it to any combination (using|, bitwise or) ofPARSE_DECLTYPESandPARSE_COLNAMESto enable this. Column names take precedence over declared types if both flags are set. By default (0), type detection is disabled.isolation_level (str | None) -- Control legacy transaction handling behaviour. See
Connection.isolation_leveland Transaction control via the isolation_level attribute for more information. Can be"DEFERRED"(default),"EXCLUSIVE"or"IMMEDIATE"; orNoneto disable opening transactions implicitly. Has no effect unlessConnection.autocommitis set toLEGACY_TRANSACTION_CONTROL(the default).check_same_thread (bool) -- If
True(default),ProgrammingErrorwill be raised if the database connection is used by a thread other than the one that created it. IfFalse, the connection may be accessed in multiple threads; write operations may need to be serialized by the user to avoid data corruption. Seethreadsafetyfor more information.factory (Connection) -- A custom subclass of
Connectionto create the connection with, if not the defaultConnectionclass.cached_statements (int) -- The number of statements that
sqlite3should internally cache for this connection, to avoid parsing overhead. By default, 128 statements.uri (bool) -- If set to
True, database is interpreted as a URI with a file path and an optional query string. The scheme part must be"file:", and the path can be relative or absolute. The query string allows passing parameters to SQLite, enabling various How to work with SQLite URIs.autocommit (bool) -- Control PEP 249 transaction handling behaviour. See
Connection.autocommitand Transaction control via the autocommit attribute for more information. autocommit currently defaults toLEGACY_TRANSACTION_CONTROL. The default will change toFalsein a future Python release.
- 回傳型別:
引發一個附帶引數
database的稽核事件sqlite3.connect。引發一個附帶引數
connection_handle的稽核事件sqlite3.connect/handle。在 3.4 版的變更: 新增 uri 參數。
在 3.7 版的變更: database can now also be a path-like object, not only a string.
在 3.10 版的變更: 新增
sqlite3.connect/handle稽核事件。在 3.12 版的變更: 新增 autocommit 參數。
在 3.13 版的變更: Positional use of the parameters timeout, detect_types, isolation_level, check_same_thread, factory, cached_statements, and uri is deprecated. They will become keyword-only parameters in Python 3.15.
- sqlite3.complete_statement(statement)¶
Return
Trueif the string statement appears to contain one or more complete SQL statements. No syntactic verification or parsing of any kind is performed, other than checking that there are no unclosed string literals and the statement is terminated by a semicolon.範例:
>>> sqlite3.complete_statement("SELECT foo FROM bar;") True >>> sqlite3.complete_statement("SELECT foo") False
This function may be useful during command-line input to determine if the entered text seems to form a complete SQL statement, or if additional input is needed before calling
execute().See
runsource()in Lib/sqlite3/__main__.py for real-world use.
- sqlite3.enable_callback_tracebacks(flag, /)¶
Enable or disable callback tracebacks. By default you will not get any tracebacks in user-defined functions, aggregates, converters, authorizer callbacks etc. If you want to debug them, you can call this function with flag set to
True. Afterwards, you will get tracebacks from callbacks onsys.stderr. UseFalseto disable the feature again.備註
Errors in user-defined function callbacks are logged as unraisable exceptions. Use an
unraisable hook handlerfor introspection of the failed callback.
- sqlite3.register_adapter(type, adapter, /)¶
Register an adapter callable to adapt the Python type type into an SQLite type. The adapter is called with a Python object of type type as its sole argument, and must return a value of a type that SQLite natively understands.
- sqlite3.register_converter(typename, converter, /)¶
Register the converter callable to convert SQLite objects of type typename into a Python object of a specific type. The converter is invoked for all SQLite values of type typename; it is passed a
bytesobject and should return an object of the desired Python type. Consult the parameter detect_types ofconnect()for information regarding how type detection works.Note: typename and the name of the type in your query are matched case-insensitively.
Module constants¶
- sqlite3.LEGACY_TRANSACTION_CONTROL¶
Set
autocommitto this constant to select old style (pre-Python 3.12) transaction control behaviour. See Transaction control via the isolation_level attribute for more information.
- sqlite3.PARSE_DECLTYPES¶
Pass this flag value to the detect_types parameter of
connect()to look up a converter function using the declared types for each column. The types are declared when the database table is created.sqlite3will look up a converter function using the first word of the declared type as the converter dictionary key. For example:CREATE TABLE test( i integer primary key, ! will look up a converter named "integer" p point, ! will look up a converter named "point" n number(10) ! will look up a converter named "number" )
This flag may be combined with
PARSE_COLNAMESusing the|(bitwise or) operator.備註
Generated fields (for example
MAX(p)) are returned asstr. UsePARSE_COLNAMESto enforce types for such queries.
- sqlite3.PARSE_COLNAMES¶
Pass this flag value to the detect_types parameter of
connect()to look up a converter function by using the type name, parsed from the query column name, as the converter dictionary key. The query column name must be wrapped in double quotes (") and the type name must be wrapped in square brackets ([]).SELECT MAX(p) as "p [point]" FROM test; ! will look up converter "point"
This flag may be combined with
PARSE_DECLTYPESusing the|(bitwise or) operator.
- sqlite3.SQLITE_OK¶
- sqlite3.SQLITE_DENY¶
- sqlite3.SQLITE_IGNORE¶
Flags that should be returned by the authorizer_callback callable passed to
Connection.set_authorizer(), to indicate whether:Access is allowed (
SQLITE_OK),The SQL statement should be aborted with an error (
SQLITE_DENY)The column should be treated as a
NULLvalue (SQLITE_IGNORE)
- sqlite3.apilevel¶
String constant stating the supported DB-API level. Required by the DB-API. Hard-coded to
"2.0".
- sqlite3.paramstyle¶
String constant stating the type of parameter marker formatting expected by the
sqlite3module. Required by the DB-API. Hard-coded to"qmark".備註
The
namedDB-API parameter style is also supported.
- sqlite3.threadsafety¶
Integer constant required by the DB-API 2.0, stating the level of thread safety the
sqlite3module supports. This attribute is set based on the default threading mode the underlying SQLite library is compiled with. The SQLite threading modes are:Single-thread: In this mode, all mutexes are disabled and SQLite is unsafe to use in more than a single thread at once.
Multi-thread: In this mode, SQLite can be safely used by multiple threads provided that no single database connection is used simultaneously in two or more threads.
Serialized: In serialized mode, SQLite can be safely used by multiple threads with no restriction.
The mappings from SQLite threading modes to DB-API 2.0 threadsafety levels are as follows:
SQLite 執行緒模式
DB-API 2.0 meaning
single-thread
0
0
Threads may not share the module
multi-thread
1
2
Threads may share the module, but not connections
serialized
3
1
Threads may share the module, connections and cursors
在 3.11 版的變更: Set threadsafety dynamically instead of hard-coding it to
1.
- sqlite3.SQLITE_DBCONFIG_DEFENSIVE¶
- sqlite3.SQLITE_DBCONFIG_DQS_DDL¶
- sqlite3.SQLITE_DBCONFIG_DQS_DML¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_FKEY¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_QPSG¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_TRIGGER¶
- sqlite3.SQLITE_DBCONFIG_ENABLE_VIEW¶
- sqlite3.SQLITE_DBCONFIG_LEGACY_ALTER_TABLE¶
- sqlite3.SQLITE_DBCONFIG_LEGACY_FILE_FORMAT¶
- sqlite3.SQLITE_DBCONFIG_NO_CKPT_ON_CLOSE¶
- sqlite3.SQLITE_DBCONFIG_RESET_DATABASE¶
- sqlite3.SQLITE_DBCONFIG_TRIGGER_EQP¶
- sqlite3.SQLITE_DBCONFIG_TRUSTED_SCHEMA¶
- sqlite3.SQLITE_DBCONFIG_WRITABLE_SCHEMA¶
These constants are used for the
Connection.setconfig()andgetconfig()methods.The availability of these constants varies depending on the version of SQLite Python was compiled with.
在 3.12 版被加入.
也參考
- https://www.sqlite.org/c3ref/c_dbconfig_defensive.html
SQLite docs: Database Connection Configuration Options
自從版本 3.12 後不推薦使用,已從版本 3.14 中移除。: The version and version_info constants.
Connection 物件¶
- class sqlite3.Connection¶
Each open SQLite database is represented by a
Connectionobject, which is created usingsqlite3.connect(). Their main purpose is creatingCursorobjects, and Transaction control.在 3.13 版的變更: A
ResourceWarningis emitted ifclose()is not called before aConnectionobject is deleted.一個 SQLite 資料庫連線具有以下屬性和方法:
- cursor(factory=Cursor)¶
Create and return a
Cursorobject. The cursor method accepts a single optional parameter factory. If supplied, this must be a callable returning an instance ofCursoror its subclasses.
- blobopen(table, column, rowid, /, *, readonly=False, name='main')¶
Open a
Blobhandle to an existing BLOB.- 參數:
table (str) -- The name of the table where the blob is located.
column (str) -- The name of the column where the blob is located.
rowid (int) -- The row id where the blob is located.
readonly (bool) -- Set to
Trueif the blob should be opened without write permissions. Defaults toFalse.name (str) -- The name of the database where the blob is located. Defaults to
"main".
- 引發:
OperationalError -- When trying to open a blob in a
WITHOUT ROWIDtable.- 回傳型別:
備註
The blob size cannot be changed using the
Blobclass. Use the SQL functionzeroblobto create a blob with a fixed size.在 3.11 版被加入.
- commit()¶
Commit any pending transaction to the database. If
autocommitisTrue, or there is no open transaction, this method does nothing. IfautocommitisFalse, a new transaction is implicitly opened if a pending transaction was committed by this method.
- rollback()¶
Roll back to the start of any pending transaction. If
autocommitisTrue, or there is no open transaction, this method does nothing. IfautocommitisFalse, a new transaction is implicitly opened if a pending transaction was rolled back by this method.
- close()¶
Close the database connection. If
autocommitisFalse, any pending transaction is implicitly rolled back. IfautocommitisTrueorLEGACY_TRANSACTION_CONTROL, no implicit transaction control is executed. Make sure tocommit()before closing to avoid losing pending changes.
- execute(sql, parameters=(), /)¶
Create a new
Cursorobject and callexecute()on it with the given sql and parameters. Return the new cursor object.
- executemany(sql, parameters, /)¶
Create a new
Cursorobject and callexecutemany()on it with the given sql and parameters. Return the new cursor object.
- executescript(sql_script, /)¶
Create a new
Cursorobject and callexecutescript()on it with the given sql_script. Return the new cursor object.
- create_function(name, narg, func, *, deterministic=False)¶
Create or remove a user-defined SQL function.
- 參數:
name (str) -- The name of the SQL function.
narg (int) -- The number of arguments the SQL function can accept. If
-1, it may take any number of arguments.func (callback | None) -- A callable that is called when the SQL function is invoked. The callable must return a type natively supported by SQLite. Set to
Noneto remove an existing SQL function.deterministic (bool) -- If
True, the created SQL function is marked as deterministic, which allows SQLite to perform additional optimizations.
在 3.8 版的變更: 新增 deterministic 參數。
範例:
>>> import hashlib >>> def md5sum(t): ... return hashlib.md5(t).hexdigest() >>> con = sqlite3.connect(":memory:") >>> con.create_function("md5", 1, md5sum) >>> for row in con.execute("SELECT md5(?)", (b"foo",)): ... print(row) ('acbd18db4cc2f85cedef654fccc4a4d8',) >>> con.close()
在 3.13 版的變更: Passing name, narg, and func as keyword arguments is deprecated. These parameters will become positional-only in Python 3.15.
- create_aggregate(name, n_arg, aggregate_class)¶
Create or remove a user-defined SQL aggregate function.
- 參數:
name (str) -- The name of the SQL aggregate function.
n_arg (int) -- The number of arguments the SQL aggregate function can accept. If
-1, it may take any number of arguments.aggregate_class (class | None) --
A class must implement the following methods:
step(): Add a row to the aggregate.finalize(): Return the final result of the aggregate as a type natively supported by SQLite.
The number of arguments that the
step()method must accept is controlled by n_arg.Set to
Noneto remove an existing SQL aggregate function.
範例:
class MySum: def __init__(self): self.count = 0 def step(self, value): self.count += value def finalize(self): return self.count con = sqlite3.connect(":memory:") con.create_aggregate("mysum", 1, MySum) cur = con.execute("CREATE TABLE test(i)") cur.execute("INSERT INTO test(i) VALUES(1)") cur.execute("INSERT INTO test(i) VALUES(2)") cur.execute("SELECT mysum(i) FROM test") print(cur.fetchone()[0]) con.close()
在 3.13 版的變更: Passing name, n_arg, and aggregate_class as keyword arguments is deprecated. These parameters will become positional-only in Python 3.15.
- create_window_function(name, num_params, aggregate_class, /)¶
Create or remove a user-defined aggregate window function.
- 參數:
name (str) -- The name of the SQL aggregate window function to create or remove.
num_params (int) -- The number of arguments the SQL aggregate window function can accept. If
-1, it may take any number of arguments.aggregate_class (class | None) --
A class that must implement the following methods:
step(): Add a row to the current window.value(): Return the current value of the aggregate.inverse(): Remove a row from the current window.finalize(): Return the final result of the aggregate as a type natively supported by SQLite.
The number of arguments that the
step()andvalue()methods must accept is controlled by num_params.Set to
Noneto remove an existing SQL aggregate window function.
- 引發:
NotSupportedError -- If used with a version of SQLite older than 3.25.0, which does not support aggregate window functions.
在 3.11 版被加入.
範例:
# Example taken from https://www.sqlite.org/windowfunctions.html#udfwinfunc class WindowSumInt: def __init__(self): self.count = 0 def step(self, value): """Add a row to the current window.""" self.count += value def value(self): """Return the current value of the aggregate.""" return self.count def inverse(self, value): """Remove a row from the current window.""" self.count -= value def finalize(self): """Return the final value of the aggregate. Any clean-up actions should be placed here. """ return self.count con = sqlite3.connect(":memory:") cur = con.execute("CREATE TABLE test(x, y)") values = [ ("a", 4), ("b", 5), ("c", 3), ("d", 8), ("e", 1), ] cur.executemany("INSERT INTO test VALUES(?, ?)", values) con.create_window_function("sumint", 1, WindowSumInt) cur.execute(""" SELECT x, sumint(y) OVER ( ORDER BY x ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING ) AS sum_y FROM test ORDER BY x """) print(cur.fetchall()) con.close()
- create_collation(name, callable, /)¶
Create a collation named name using the collating function callable. callable is passed two
stringarguments, and it should return aninteger:1if the first is ordered higher than the second-1if the first is ordered lower than the second0if they are ordered equal
The following example shows a reverse sorting collation:
def collate_reverse(string1, string2): if string1 == string2: return 0 elif string1 < string2: return 1 else: return -1 con = sqlite3.connect(":memory:") con.create_collation("reverse", collate_reverse) cur = con.execute("CREATE TABLE test(x)") cur.executemany("INSERT INTO test(x) VALUES(?)", [("a",), ("b",)]) cur.execute("SELECT x FROM test ORDER BY x COLLATE reverse") for row in cur: print(row) con.close()
Remove a collation function by setting callable to
None.在 3.11 版的變更: The collation name can contain any Unicode character. Earlier, only ASCII characters were allowed.
- interrupt()¶
Call this method from a different thread to abort any queries that might be executing on the connection. Aborted queries will raise an
OperationalError.
- set_authorizer(authorizer_callback)¶
Register callable authorizer_callback to be invoked for each attempt to access a column of a table in the database. The callback should return one of
SQLITE_OK,SQLITE_DENY, orSQLITE_IGNOREto signal how access to the column should be handled by the underlying SQLite library.The first argument to the callback signifies what kind of operation is to be authorized. The second and third argument will be arguments or
Nonedepending 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 inner-most trigger or view that is responsible for the access attempt orNoneif this access attempt is directly from input SQL code.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 one. All necessary constants are available in the
sqlite3module.Passing
Noneas authorizer_callback will disable the authorizer.在 3.11 版的變更: 新增使用
None來停用授權器的支援。在 3.13 版的變更: Passing authorizer_callback as a keyword argument is deprecated. The parameter will become positional-only in Python 3.15.
- set_progress_handler(progress_handler, n)¶
Register callable progress_handler to be invoked for every n 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 a GUI.
If you want to clear any previously installed progress handler, call the method with
Nonefor progress_handler.Returning a non-zero value from the handler function will terminate the currently executing query and cause it to raise a
DatabaseErrorexception.在 3.13 版的變更: Passing progress_handler as a keyword argument is deprecated. The parameter will become positional-only in Python 3.15.
- set_trace_callback(trace_callback)¶
Register callable trace_callback to be invoked for each SQL statement that is actually executed by the SQLite backend.
The only argument passed to the callback is the statement (as
str) that is being executed. The return value of the callback is ignored. Note that the backend does not only run statements passed to theCursor.execute()methods. Other sources include the transaction management of thesqlite3module and the execution of triggers defined in the current database.Passing
Noneas trace_callback will disable the trace callback.備註
Exceptions raised in the trace callback are not propagated. As a development and debugging aid, use
enable_callback_tracebacks()to enable printing tracebacks from exceptions raised in the trace callback.在 3.3 版被加入.
在 3.13 版的變更: Passing trace_callback as a keyword argument is deprecated. The parameter will become positional-only in Python 3.15.
- enable_load_extension(enabled, /)¶
Enable the SQLite engine to load SQLite extensions from shared libraries if enabled is
True; else, disallow loading SQLite extensions. SQLite extensions can define new functions, aggregates or whole new virtual table implementations. One well-known extension is the fulltext-search extension distributed with SQLite.備註
The
sqlite3module is not built with loadable extension support by default, because some platforms (notably macOS) have SQLite libraries which are compiled without this feature. To get loadable extension support, you must pass the--enable-loadable-sqlite-extensionsoption to configure.引發一個附帶引數
connection、enabled的稽核事件sqlite3.enable_load_extension。在 3.2 版被加入.
在 3.10 版的變更: 加入
sqlite3.enable_load_extension稽核事件。con.enable_load_extension(True) # Load the fulltext search extension con.execute("select load_extension('./fts3.so')") # alternatively you can load the extension using an API call: # con.load_extension("./fts3.so") # disable extension loading again con.enable_load_extension(False) # example from SQLite wiki con.execute("CREATE VIRTUAL TABLE recipe USING fts3(name, ingredients)") con.executescript(""" INSERT INTO recipe (name, ingredients) VALUES('broccoli stew', 'broccoli peppers cheese tomatoes'); INSERT INTO recipe (name, ingredients) VALUES('pumpkin stew', 'pumpkin onions garlic celery'); INSERT INTO recipe (name, ingredients) VALUES('broccoli pie', 'broccoli cheese onions flour'); INSERT INTO recipe (name, ingredients) VALUES('pumpkin pie', 'pumpkin sugar flour butter'); """) for row in con.execute("SELECT rowid, name, ingredients FROM recipe WHERE name MATCH 'pie'"): print(row)
- load_extension(path, /, *, entrypoint=None)¶
Load an SQLite extension from a shared library. Enable extension loading with
enable_load_extension()before calling this method.- 參數:
path (str) -- The path to the SQLite extension.
entrypoint (str | None) -- Entry point name. If
None(the default), SQLite will come up with an entry point name of its own; see the SQLite docs Loading an Extension for details.
引發一個附帶引數
connection、path的稽核事件sqlite3.load_extension。在 3.2 版被加入.
在 3.10 版的變更: 加入
sqlite3.load_extension稽核事件。在 3.12 版的變更: 新增 entrypoint 參數。
- iterdump(*, filter=None)¶
Return an iterator to dump the database as SQL source code. Useful when saving an in-memory database for later restoration. Similar to the
.dumpcommand in the sqlite3 shell.- 參數:
filter (str | None) -- An optional
LIKEpattern for database objects to dump, e.g.prefix_%. IfNone(the default), all database objects will be included.
範例:
# Convert file example.db to SQL dump file dump.sql con = sqlite3.connect('example.db') with open('dump.sql', 'w') as f: for line in con.iterdump(): f.write('%s\n' % line) con.close()
在 3.13 版的變更: 新增 filter 參數。
- backup(target, *, pages=-1, progress=None, name='main', sleep=0.250)¶
Create a backup of an SQLite database.
Works even if the database is being accessed by other clients or concurrently by the same connection.
- 參數:
target (Connection) -- The database connection to save the backup to.
pages (int) -- The number of pages to copy at a time. If equal to or less than
0, the entire database is copied in a single step. Defaults to-1.progress (callback | None) -- If set to a callable, it is invoked with three integer arguments for every backup iteration: the status of the last iteration, the remaining number of pages still to be copied, and the total number of pages. Defaults to
None.name (str) -- The name of the database to back up. Either
"main"(the default) for the main database,"temp"for the temporary database, or the name of a custom database as attached using theATTACH DATABASESQL statement.sleep (float) -- The number of seconds to sleep between successive attempts to back up remaining pages.
Example 1, copy an existing database into another:
def progress(status, remaining, total): print(f'Copied {total-remaining} of {total} pages...') src = sqlite3.connect('example.db') dst = sqlite3.connect('backup.db') with dst: src.backup(dst, pages=1, progress=progress) dst.close() src.close()
Example 2, copy an existing database into a transient copy:
src = sqlite3.connect('example.db') dst = sqlite3.connect(':memory:'