]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Be careful to maintain the value of 'txn' as long as there are active does-not-work
authordrh <>
Wed, 8 Feb 2023 19:45:11 +0000 (19:45 +0000)
committerdrh <>
Wed, 8 Feb 2023 19:45:11 +0000 (19:45 +0000)
statements.

FossilOrigin-Name: 98d10cb52add1439f67d353e499fcc8ffddf8c5c7be51b765042e7d75a29c310

manifest
manifest.uuid
src/vdbeaux.c
test/date.test

index 69073840ef99114884c8493b51fc82d35c6cc2d3..b9728702c479e04047d1fb833467ecd4b4d97853 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Always\suse\s64-bit\sintegers\sfor\sstats\sassociated\swith\sSTAT1\sand\sSTAT4.
-D 2023-02-08T17:28:42.250
+C Be\scareful\sto\smaintain\sthe\svalue\sof\s'txn'\sas\slong\sas\sthere\sare\sactive\nstatements.
+D 2023-02-08T19:45:11.710
 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
@@ -695,7 +695,7 @@ F src/vdbe.c 47d3b78e75e239e1909933f0d77612b4111ebe760f01fdd0085e4e30b59b4cc6
 F src/vdbe.h 73b904a6b3bb27f308c6cc287a5751ebc7f1f89456be0ed068a12b92844c6e8c
 F src/vdbeInt.h a4147a4ddf613cb1bcb555ace9e9e74a9c099d65facd88155f191b1fb4d74cfb
 F src/vdbeapi.c be64df0e21a43056b62f46777749347b7d51f6e5e6c419c4bf42ce9bf98d6064
-F src/vdbeaux.c 9f2a2ec80ff90266ab603065c32dd3c8b0a53023ab7210a03fccf324ad6ddbce
+F src/vdbeaux.c 617c01bede8178145d72f7e58e9fa240712e6ed51637ee786df3362658f894f5
 F src/vdbeblob.c 5e61ce31aca17db8fb60395407457a8c1c7fb471dde405e0cd675974611dcfcd
 F src/vdbemem.c 86908c0ab1624df678458feb53319bf9720992e761cbccf77a36d671ce11693d
 F src/vdbesort.c 43756031ca7430f7aec3ef904824a7883c4ede783e51f280d99b9b65c0796e35
@@ -910,7 +910,7 @@ F test/ctime.test 340f362f41f92972bbd71f44e10569a5cc694062b692231bd08aa6fe6c1c47
 F test/cursorhint.test 0175e4404181ace3ceca8b114eb0a98eae600d565aa4e2705abbe6614c7fe201
 F test/cursorhint2.test 6f3aa9cb19e7418967a10ec6905209bcbb5968054da855fc36c8beee9ae9c42f
 F test/dataversion1.test 6e5e86ac681f0782e766ebcb56c019ae001522d114e0e111e5ebf68ccf2a7bb8
-F test/date.test 8e9ae588d832c54fa2512b0f9789bea48442ada0736dabee54b377dc1b8d4a87
+F test/date.test 6220d9c15ff96731a58cf98a35375919480c4ac4746c6f50460a696a045ce288
 F test/date2.test 7e12ec14aaf4d5e6294b4ba140445b0eca06ea50062a9c3a69c4ee13d0b6f8b1
 F test/date3.test a1b77abf05c6772fe5ca2337cac1398892f2a41e62bce7e6be0f4a08a0e64ae5
 F test/dbdata.test 042f49acff3438f940eeba5868d3af080ae64ddf26ae78f80c92bec3ca7d8603
@@ -2045,8 +2045,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
 F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 459d986d38fc0ccbfd66801e0f22900cfed831268cf59ac8d1cd1e556f0d1441
-R 7d765c5331bdc4fd6218383f0460f3b4
+P 6647d1cb8b53102c8114b1f3e34173d907504d78aa3140eab53f88027a36660b
+R c171f712135088b4542adb6301c9c0c2
 U drh
-Z d38d730b036fdc5d765ac843fc1e375f
+Z 663a5d5c960b60a878ce4b8ec6484d4d
 # Remove this line to create a well-formed Fossil manifest.
index cec0c36a0c5dbc179107e81cb6bd7e2ed7c32e2c..94843bd8f90c93fd31ae334cab88377f597503c7 100644 (file)
@@ -1 +1 @@
-6647d1cb8b53102c8114b1f3e34173d907504d78aa3140eab53f88027a36660b
\ No newline at end of file
+98d10cb52add1439f67d353e499fcc8ffddf8c5c7be51b765042e7d75a29c310
\ No newline at end of file
index 82dc6071540702006a5ec819e2ecf04ee8c50f89..0d7bd30d20e6a48bc418d2da640b08433c308328 100644 (file)
@@ -3376,7 +3376,7 @@ int sqlite3VdbeHalt(Vdbe *p){
   }
 
   /* We have successfully halted and closed the VM.  Record this fact. */
-  db->nVdbeActive--;
+  if( (--db->nVdbeActive)==0 && db->autoCommit )  db->txnTime = 0;
   if( !p->readOnly ) db->nVdbeWrite--;
   if( p->bIsReader ) db->nVdbeRead--;
   assert( db->nVdbeActive>=db->nVdbeRead );
@@ -3394,7 +3394,6 @@ int sqlite3VdbeHalt(Vdbe *p){
   */
   if( db->autoCommit ){
     sqlite3ConnectionUnlocked(db);
-    db->txnTime = 0;
   }
 
   assert( db->nVdbeActive>0 || db->autoCommit==0 || db->nStatement==0 );
index 479635753a40cb41cbc49265bd57d5ea4fb96ac8..74c35293fcb6fd9b8f10f6e673b78789807f1e1d 100644 (file)
@@ -557,6 +557,17 @@ do_test date-15.10 {
 } {1 1 1 0 0}
 db eval {COMMIT}
 
+reset_db
+do_test date-15.11 {
+  db eval {CREATE TABLE t1(x);}
+  db eval {VALUES(1),(2),(3)} {
+    db eval {INSERT INTO t1(x) VALUES(julianday('txn'))}
+    after 10
+  }
+  db eval {SELECT count(x), count(DISTINCT x) FROM t1}
+} {3 1}
+
+
 # Tests of extreme values in date/time functions.  Run with UBSan or the
 # equivalent to verify no signed interger overflow warnings.
 #