Kaydet (Commit) 002b2020 authored tarafından Petri Lehtinen's avatar Petri Lehtinen

Fix errors in sqlite3's Cursor.rowcount documentation

Closes #13995.
üst 14dc5103
...@@ -17,5 +17,4 @@ con.executemany("insert into person(firstname, lastname) values (?, ?)", persons ...@@ -17,5 +17,4 @@ con.executemany("insert into person(firstname, lastname) values (?, ?)", persons
for row in con.execute("select firstname, lastname from person"): for row in con.execute("select firstname, lastname from person"):
print row print row
# Using a dummy WHERE clause to not let SQLite take the shortcut table deletes. print "I just deleted", con.execute("delete from person").rowcount, "rows"
print "I just deleted", con.execute("delete from person where 1=1").rowcount, "rows"
...@@ -548,18 +548,17 @@ Cursor Objects ...@@ -548,18 +548,17 @@ Cursor Objects
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 ``DELETE`` statements, SQLite reports :attr:`rowcount` as 0 if you make a
``DELETE FROM table`` without any condition.
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". last operation is not determinable by the interface". This includes ``SELECT``
statements because we cannot determine the number of rows a query produced
until all rows were fetched.
This includes ``SELECT`` statements because we cannot determine the number of With SQLite versions before 3.6.5, :attr:`rowcount` is set to 0 if
rows a query produced until all rows were fetched. you make a ``DELETE FROM table`` without any condition.
.. attribute:: Cursor.lastrowid .. attribute:: Cursor.lastrowid
......
...@@ -575,6 +575,8 @@ Tests ...@@ -575,6 +575,8 @@ Tests
Documentation Documentation
------------- -------------
- Issue #13995: Fix errors in sqlite3's Cursor.rowcount documentation
- Issue #13402: Document absoluteness of sys.executable. - Issue #13402: Document absoluteness of sys.executable.
- Issue #13883: PYTHONCASEOK also works on OS X, OS/2, and RiscOS. - Issue #13883: PYTHONCASEOK also works on OS X, OS/2, and RiscOS.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment