From: drh <> Date: Tue, 21 Jun 2022 18:38:18 +0000 (+0000) Subject: Disable the short-cut query planner if the NOT INDEXED modifier is used. X-Git-Tag: version-3.39.0~13 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8c44962aaffa59d579db49b44c085dbdb108af34;p=thirdparty%2Fsqlite.git Disable the short-cut query planner if the NOT INDEXED modifier is used. [forum:/forumpost/454d706296|Forum post 454d706296]. FossilOrigin-Name: bd87d107fe474ceeac8bacb01c80bc479edbc2ae4e30697bf54ab91a5a8d2a98 --- diff --git a/manifest b/manifest index da777bfc04..3287f064ba 100644 --- a/manifest +++ b/manifest @@ -1,5 +1,5 @@ -C Allow\sa\sHAVING\sclause\son\sany\saggregate\squery,\seven\sif\sthere\sis\sno\sGROUP\sBY\nclause.\s\sThis\sbrings\sSQLite\sinto\scloser\sagreement\swith\sPostgreSQL\sand\sfixes\nthe\sconcern\sraised\sby\s\n[forum:/forumpost/1a7fea4651|forum\spost\s1a7fea4651]. -D 2022-06-21T13:41:24.351 +C Disable\sthe\sshort-cut\squery\splanner\sif\sthe\sNOT\sINDEXED\smodifier\sis\sused.\n[forum:/forumpost/454d706296|Forum\spost\s454d706296]. +D 2022-06-21T18:38:18.478 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724 @@ -657,7 +657,7 @@ F src/vxworks.h d2988f4e5a61a4dfe82c6524dd3d6e4f2ce3cdb9 F src/wal.c b9df133a705093da8977da5eb202eaadb844839f1c7297c08d33471f5491843d F src/wal.h c3aa7825bfa2fe0d85bef2db94655f99870a285778baa36307c0a16da32b226a F src/walker.c f890a3298418d7cba3b69b8803594fdc484ea241206a8dfa99db6dd36f8cbb3b -F src/where.c ce4cb0246b6a21bbc728405ade013e1ea2d8d7662e720bf3601cdf57877738fd +F src/where.c 518fd39eb7d0fa7bea59d990fb41dc369206d58f42257718ed01fdc814ce55c9 F src/whereInt.h b48ca529ffe293c18cbfa8326af18a09e39910de66fb3e96ef788c7cbf8ef3a7 F src/wherecode.c 0b09abfcb88c61c6a6984a3e065786631ff35495e9bdf865e6b74ab0a1299c5b F src/whereexpr.c 4dae5e39a813224bec5bc404ebc328ad369766c39652692ae145e0870ca4cc5b @@ -1978,8 +1978,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 364645d8fe22491cd566e868027e739464205e892753356016b1988ead207af4 -R b811a955eaf3f4f24a3997e7a988ecb5 +P 9322a7c21f1c22ba00e9b889223e89bc1591db6e561ce05091e905e98c1bf2b3 +R dc1b0ba1ee85a7e377a271938e5a33d9 U drh -Z 1ff0c2c17df919cd17badf81d6bc1850 +Z 22b60deef4a05bbb68a5eab2c13bab74 # Remove this line to create a well-formed Fossil manifest. diff --git a/manifest.uuid b/manifest.uuid index 00c7a12629..332c085d34 100644 --- a/manifest.uuid +++ b/manifest.uuid @@ -1 +1 @@ -9322a7c21f1c22ba00e9b889223e89bc1591db6e561ce05091e905e98c1bf2b3 \ No newline at end of file +bd87d107fe474ceeac8bacb01c80bc479edbc2ae4e30697bf54ab91a5a8d2a98 \ No newline at end of file diff --git a/src/where.c b/src/where.c index 196c508b0d..4095a52137 100644 --- a/src/where.c +++ b/src/where.c @@ -5083,7 +5083,11 @@ static int whereShortCut(WhereLoopBuilder *pBuilder){ pItem = pWInfo->pTabList->a; pTab = pItem->pTab; if( IsVirtual(pTab) ) return 0; - if( pItem->fg.isIndexedBy ) return 0; + if( pItem->fg.isIndexedBy || pItem->fg.notIndexed ){ + testcase( pItem->fg.isIndexedBy ); + testcase( pItem->fg.notIndexed ); + return 0; + } iCur = pItem->iCursor; pWC = &pWInfo->sWC; pLoop = pBuilder->pNew;