From: drh <> Date: Thu, 18 Sep 2025 18:56:55 +0000 (+0000) Subject: Include I/O consumed by ephermeral cursors in the SQLITE_DBSTATUS_SPILL X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=7cbfa5b0d124f03cedbd47a1aaf2be1ea3feb062;p=thirdparty%2Fsqlite.git Include I/O consumed by ephermeral cursors in the SQLITE_DBSTATUS_SPILL values. Still need to add sorter. FossilOrigin-Name: 118905b26a96825433f79b47fd3e7c2bdb137d84292fb9419e4436a961a9833a --- diff --git a/manifest b/manifest index c29aeb9b1d..07fa32d267 100644 --- a/manifest +++ b/manifest @@ -1,5 +1,5 @@ -C Initial\simplementation\sof\sSQLITE_DBSTATUS_SPILL.\s\sDoes\snot\syet\stake\sinto\naccount\ssorters\sor\stransient\stables. -D 2025-09-18T14:51:23.014 +C Include\sI/O\sconsumed\sby\sephermeral\scursors\sin\sthe\sSQLITE_DBSTATUS_SPILL\nvalues.\s\sStill\sneed\sto\sadd\ssorter. +D 2025-09-18T18:56:55.622 F .fossil-settings/binary-glob 61195414528fb3ea9693577e1980230d78a1f8b0a54c78cf1b9b24d0a409ed6a x F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea @@ -744,7 +744,7 @@ F src/resolve.c f8d1d011aba0964ff1bdccd049d4d2c2fec217efd90d202a4bb775e926b2c25d F src/rowset.c 8432130e6c344b3401a8874c3cb49fefe6873fec593294de077afea2dce5ec97 F src/select.c b95181711d59c36d9789e67f76c4cfec64b99f9629a50be5e6566e117b87d957 F src/shell.c.in 6ca902bb9aa56ae7f83769b39652b975fd0b347f984ab13f4565de80e4ecb3e9 -F src/sqlite.h.in 31dcc6e5a55e308438034faf80ebca13d7331ac5a87136d5caa0baff957fe13f +F src/sqlite.h.in 9fca8150225467bef7a1c378f00f5ef8f795e20cb450df67f82963e62fafcbe3 F src/sqlite3.rc 015537e6ac1eec6c7050e17b616c2ffe6f70fca241835a84a4f0d5937383c479 F src/sqlite3ext.h 3f0c4ed6934e7309a61c6f3c30f70a30a5b869f785bb3d9f721a36c5e4359126 F src/sqliteInt.h 87418f40cbdd986b4a58c649e598fd6cde89e98d3b5c770d2899b5f6c755ebb9 @@ -813,7 +813,7 @@ F src/vdbe.c 07084aa0152c8d4e74e7b86c0cf744732f0f9b1fd62bd7098252cadb741c630a F src/vdbe.h ea1f1b52f0efe422f80d88da3c57e4eadc72856e29a22f1ff08e502ec6ba5f08 F src/vdbeInt.h 52896dd4d5b62190c53db14b09fc2484434eb594c963df0fa66eb8a94527b02e F src/vdbeapi.c f9a4881a9674fec3fa13da35044a1484d3c4b95f9ec891cc8ffb02ef2b7a41df -F src/vdbeaux.c b701e5920fe74b907eb8211d1f63fef96adc65dfd6e1ad6ed0843c71d8c65205 +F src/vdbeaux.c a0718e0ff1e336f7d9b4df5a7fe38fc6eb9b3779871e3768d060fa88a76b8d14 F src/vdbeblob.c b3f0640db9642fbdc88bd6ebcc83d6009514cafc98f062f675f2c8d505d82692 F src/vdbemem.c e67d9c6484d868c879d20c70d00bf4a9058082f1d4058607ca15d50eb3aebc21 F src/vdbesort.c cb6f472e83ca12c46aa7de0ac0a9d11458b357986f2617a1c90dfb19a542ecbe @@ -2175,11 +2175,8 @@ F tool/version-info.c 3b36468a90faf1bbd59c65fd0eb66522d9f941eedd364fabccd7227350 F tool/warnings-clang.sh bbf6a1e685e534c92ec2bfba5b1745f34fb6f0bc2a362850723a9ee87c1b31a7 F tool/warnings.sh 1ad0169b022b280bcaaf94a7fa231591be96b514230ab5c98fbf15cd7df842dd F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f -P bb5b982dba774e6b8011e6c980d34131c378967fadc59a18fed1cefda596449a -R bf295d84b4712b604b76c3297c606f19 -T *branch * dbstatus-spill -T *sym-dbstatus-spill * -T -sym-db-status64 * +P 4e63ee20f80e486ecc4aa4523afa43f994c267e638f8f084f0d6df369aa74a1d +R 23ddf07861ed9bfd32891e000fdd4062 U drh -Z 8d1169484e2c5669b92530153307ed69 +Z aaf208a8aa761385255c814551acbbd3 # Remove this line to create a well-formed Fossil manifest. diff --git a/manifest.uuid b/manifest.uuid index 25fcf57a27..2c8916bb36 100644 --- a/manifest.uuid +++ b/manifest.uuid @@ -1 +1 @@ -4e63ee20f80e486ecc4aa4523afa43f994c267e638f8f084f0d6df369aa74a1d +118905b26a96825433f79b47fd3e7c2bdb137d84292fb9419e4436a961a9833a diff --git a/src/sqlite.h.in b/src/sqlite.h.in index 273a4893d1..2bf16be3b2 100644 --- a/src/sqlite.h.in +++ b/src/sqlite.h.in @@ -9029,6 +9029,10 @@ int sqlite3_db_status64(sqlite3*,int,sqlite3_int64*,sqlite3_int64*,int); ** If an IO or other error occurs while writing a page to disk, the effect ** on subsequent SQLITE_DBSTATUS_CACHE_WRITE requests is undefined.)^ ^The ** highwater mark associated with SQLITE_DBSTATUS_CACHE_WRITE is always 0. +**

+** ^(There is overlap between the quantities measured by this parameter +** (SQLITE_DBSTATUS_CACHE_WRITE) and SQLITE_DBSTATUS_SPILL. Resetting one +** will reduce the other.)^ ** ** ** [[SQLITE_DBSTATUS_CACHE_SPILL]] ^(

SQLITE_DBSTATUS_CACHE_SPILL
@@ -9052,6 +9056,10 @@ int sqlite3_db_status64(sqlite3*,int,sqlite3_int64*,sqlite3_int64*,int); ** are part of complex queries, external sorts that spill to disk, and ** writes to TEMP tables.)^ ** ^The highwater mark is always 0. +**

+** ^(There is overlap between the quantities measured by this parameter +** (SQLITE_DBSTATUS_SPILL) and SQLITE_DBSTATUS_CACHE_WRITE. Resetting one +** will reduce the other.)^ ** ** */ diff --git a/src/vdbeaux.c b/src/vdbeaux.c index c8b86e6f6d..cf2b209c13 100644 --- a/src/vdbeaux.c +++ b/src/vdbeaux.c @@ -2758,30 +2758,47 @@ static SQLITE_NOINLINE void freeCursorWithCache(Vdbe *p, VdbeCursor *pCx){ sqlite3DbFree(p->db, pCache); sqlite3VdbeFreeCursorNN(p, pCx); } +static SQLITE_NOINLINE void freeCursorEphemeral(Vdbe *p, VdbeCursor *pCx){ + u64 nByte = 0; + Pager *pPager; + assert( pCx->eCurType==CURTYPE_BTREE ); + assert( pCx->isEphemeral ); + if( pCx->ub.pBtx ){ + pPager = sqlite3BtreePager(pCx->ub.pBtx); + sqlite3PagerCacheStat(pPager, SQLITE_DBSTATUS_CACHE_WRITE, 0, &nByte); + nByte *= sqlite3BtreeGetPageSize(pCx->ub.pBtx); + p->db->nSpill += nByte; + } + pCx->isEphemeral = 0; + sqlite3VdbeFreeCursorNN(p, pCx); +} +#ifndef SQLITE_OMIT_VIRTUALTABLE +static SQLITE_NOINLINE void freeCursorVTab(Vdbe *p, VdbeCursor *pCx){ + sqlite3_vtab_cursor *pVCur; + const sqlite3_module *pModule; + assert( pCx->eCurType==CURTYPE_VTAB ); + pVCur = pCx->uc.pVCur; + pModule = pVCur->pVtab->pModule; + assert( pVCur->pVtab->nRef>0 ); + pVCur->pVtab->nRef--; + pModule->xClose(pVCur); +} +#endif void sqlite3VdbeFreeCursorNN(Vdbe *p, VdbeCursor *pCx){ if( pCx->colCache ){ freeCursorWithCache(p, pCx); - return; - } - switch( pCx->eCurType ){ - case CURTYPE_SORTER: { - sqlite3VdbeSorterClose(p->db, pCx); - break; - } - case CURTYPE_BTREE: { + }else if( pCx->eCurType==CURTYPE_BTREE ){ + if( pCx->isEphemeral ){ + freeCursorEphemeral(p,pCx); + }else{ assert( pCx->uc.pCursor!=0 ); sqlite3BtreeCloseCursor(pCx->uc.pCursor); - break; } + }else if( pCx->eCurType==CURTYPE_SORTER ){ + sqlite3VdbeSorterClose(p->db, pCx); #ifndef SQLITE_OMIT_VIRTUALTABLE - case CURTYPE_VTAB: { - sqlite3_vtab_cursor *pVCur = pCx->uc.pVCur; - const sqlite3_module *pModule = pVCur->pVtab->pModule; - assert( pVCur->pVtab->nRef>0 ); - pVCur->pVtab->nRef--; - pModule->xClose(pVCur); - break; - } + }else if( pCx->eCurType==CURTYPE_VTAB ){ + freeCursorVTab(p, pCx); #endif } }