From 8ad00a2c50b69fbf990efa367fdc4345a1cd9086 Mon Sep 17 00:00:00 2001 From: "Erlend E. Aasland" Date: Mon, 8 May 2023 12:15:29 +0200 Subject: [PATCH] gh-101117: Improve accuracy of sqlite3.Cursor.rowcount docs The SQLite C API sqlite3_changes() can only be relied upon when the statment has been run to completion. --- Doc/library/sqlite3.rst | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Doc/library/sqlite3.rst b/Doc/library/sqlite3.rst index 89673b8006ae77..e7129fb3e4de6d 100644 --- a/Doc/library/sqlite3.rst +++ b/Doc/library/sqlite3.rst @@ -1694,7 +1694,10 @@ Cursor objects ``INSERT``, ``UPDATE``, ``DELETE``, and ``REPLACE`` statements; is ``-1`` for other statements, including :abbr:`CTE (Common Table Expression)` queries. - It is only updated by the :meth:`execute` and :meth:`executemany` methods. + It is only updated by the :meth:`execute` and :meth:`executemany` methods, + after the statement has run to completion. + This means that any resulting rows must be fetched in order for + :attr:`!rowcount` to be updated. .. attribute:: row_factory