mirror of
https://github.com/python/cpython.git
synced 2025-08-03 00:23:06 +00:00
bpo-44106: Improve sqlite3 example database contents (GH-26027)
This commit is contained in:
parent
9014437573
commit
92d1064727
9 changed files with 37 additions and 42 deletions
|
@ -1,19 +1,19 @@
|
|||
import sqlite3
|
||||
|
||||
con = sqlite3.connect(":memory:")
|
||||
con.execute("create table person (id integer primary key, firstname varchar unique)")
|
||||
con.execute("create table lang (id integer primary key, name varchar unique)")
|
||||
|
||||
# Successful, con.commit() is called automatically afterwards
|
||||
with con:
|
||||
con.execute("insert into person(firstname) values (?)", ("Joe",))
|
||||
con.execute("insert into lang(name) values (?)", ("Python",))
|
||||
|
||||
# con.rollback() is called after the with block finishes with an exception, the
|
||||
# exception is still raised and must be caught
|
||||
try:
|
||||
with con:
|
||||
con.execute("insert into person(firstname) values (?)", ("Joe",))
|
||||
con.execute("insert into lang(name) values (?)", ("Python",))
|
||||
except sqlite3.IntegrityError:
|
||||
print("couldn't add Joe twice")
|
||||
print("couldn't add Python twice")
|
||||
|
||||
# Connection object used as context manager only commits or rollbacks transactions,
|
||||
# so the connection object should be closed manually
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue