Rename the SELECTTRACE macro to TREETRACE, so that is corresponds to the new
CLI command. Renumber all of the bits in the bitmask used to enable various kinds of tracing, and add a trace bitmap decoder in sqliteInt.h. Changes to debugging logic only. No (intentional) changes to production code. FossilOrigin-Name: 8036445a36d9d982c1305935e7e37367bdf9e466b923eb6286b52524802e3ccd
This commit is contained in:
parent
c9b7d943ad
commit
5d7aef16bf
16
manifest
16
manifest
@ -1,5 +1,5 @@
|
|||||||
C Fix\sthe\serror\smessage\sin\sthe\sCLI\sfor\s"no\ssuch\sVFS".\n[forum:/info/1217fdd6b3|Forum\spost\s1217fdd6b3].
|
C Rename\sthe\sSELECTTRACE\smacro\sto\sTREETRACE,\sso\sthat\sis\scorresponds\sto\sthe\snew\nCLI\scommand.\s\sRenumber\sall\sof\sthe\sbits\sin\sthe\sbitmask\sused\sto\senable\nvarious\skinds\sof\stracing,\sand\sadd\sa\strace\sbitmap\sdecoder\sin\ssqliteInt.h.\nChanges\sto\sdebugging\slogic\sonly.\s\sNo\s(intentional)\schanges\sto\sproduction\scode.
|
||||||
D 2022-11-22T18:24:07.441
|
D 2022-11-22T19:49:16.908
|
||||||
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
||||||
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
||||||
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
||||||
@ -641,12 +641,12 @@ F src/printf.c e99ee9741e79ae3873458146f59644276657340385ade4e76a5f5d1c25793764
|
|||||||
F src/random.c 606b00941a1d7dd09c381d3279a058d771f406c5213c9932bbd93d5587be4b9c
|
F src/random.c 606b00941a1d7dd09c381d3279a058d771f406c5213c9932bbd93d5587be4b9c
|
||||||
F src/resolve.c efea4e5fbecfd6d0a9071b0be0d952620991673391b6ffaaf4c277b0bb674633
|
F src/resolve.c efea4e5fbecfd6d0a9071b0be0d952620991673391b6ffaaf4c277b0bb674633
|
||||||
F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
|
F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
|
||||||
F src/select.c 3fc60a8f0b54db15e86584c5fd68dbf63c20fe86886a39267ce7dfc17b68853d
|
F src/select.c 4c48373abb4e67129c36bc15d1f5a99a0dfd9534afeb539a2169a09ae91ccec9
|
||||||
F src/shell.c.in 7d1705f139e6762e8c0fe254a8ebf3ab77aec6d8366f033cdd5f5ebadefbbb20
|
F src/shell.c.in 7d1705f139e6762e8c0fe254a8ebf3ab77aec6d8366f033cdd5f5ebadefbbb20
|
||||||
F src/sqlite.h.in 100fc660c2f19961b8ed8437b9d53d687de2f8eb2b96437ec6da216adcb643ca
|
F src/sqlite.h.in 100fc660c2f19961b8ed8437b9d53d687de2f8eb2b96437ec6da216adcb643ca
|
||||||
F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
|
F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
|
||||||
F src/sqlite3ext.h c4b9fa7a7e2bcdf850cfeb4b8a91d5ec47b7a00033bc996fd2ee96cbf2741f5f
|
F src/sqlite3ext.h c4b9fa7a7e2bcdf850cfeb4b8a91d5ec47b7a00033bc996fd2ee96cbf2741f5f
|
||||||
F src/sqliteInt.h 42bcbb6cebef64c99068e7bc141a2541d40d65c7c26a9ca5ada4d83ca353555d
|
F src/sqliteInt.h 3bdf90cb7578dfccfd3e8c0f9c8b0eecc5280f5813891d6b3016cd6f1bdb1f7e
|
||||||
F src/sqliteLimit.h d7323ffea5208c6af2734574bae933ca8ed2ab728083caa117c9738581a31657
|
F src/sqliteLimit.h d7323ffea5208c6af2734574bae933ca8ed2ab728083caa117c9738581a31657
|
||||||
F src/status.c 160c445d7d28c984a0eae38c144f6419311ed3eace59b44ac6dafc20db4af749
|
F src/status.c 160c445d7d28c984a0eae38c144f6419311ed3eace59b44ac6dafc20db4af749
|
||||||
F src/table.c 0f141b58a16de7e2fbe81c308379e7279f4c6b50eb08efeec5892794a0ba30d1
|
F src/table.c 0f141b58a16de7e2fbe81c308379e7279f4c6b50eb08efeec5892794a0ba30d1
|
||||||
@ -732,7 +732,7 @@ F src/where.c ea0f518df9e00aa44013a1d384090b4b3a499ee11d4daa0a7d99c4eb9f7ab4ba
|
|||||||
F src/whereInt.h df0c79388c0b71b4a91f480d02791679fe0345d40410435c541c8893e95a4d3f
|
F src/whereInt.h df0c79388c0b71b4a91f480d02791679fe0345d40410435c541c8893e95a4d3f
|
||||||
F src/wherecode.c 133a94f82858787217d073143617df19e4a6a7d0b771a1519f957608109ad5a5
|
F src/wherecode.c 133a94f82858787217d073143617df19e4a6a7d0b771a1519f957608109ad5a5
|
||||||
F src/whereexpr.c 05295b44b54eea76d1ba766f0908928d0e20e990c249344c9521454d3d09c7ae
|
F src/whereexpr.c 05295b44b54eea76d1ba766f0908928d0e20e990c249344c9521454d3d09c7ae
|
||||||
F src/window.c 928e215840e2f2d9a2746e018c9643ef42c66c4ab6630ef0df7fa388fa145e86
|
F src/window.c 14836767adb26573b50f528eb37f8b1336f2c430ab38de7cead1e5c546bb4d8c
|
||||||
F test/8_3_names.test ebbb5cd36741350040fd28b432ceadf495be25b2
|
F test/8_3_names.test ebbb5cd36741350040fd28b432ceadf495be25b2
|
||||||
F test/affinity2.test ce1aafc86e110685b324e9a763eab4f2a73f737842ec3b687bd965867de90627
|
F test/affinity2.test ce1aafc86e110685b324e9a763eab4f2a73f737842ec3b687bd965867de90627
|
||||||
F test/affinity3.test b5c19d504dec222c0dc66642673d23dce915d35737b68e74d9f237b80493eb53
|
F test/affinity3.test b5c19d504dec222c0dc66642673d23dce915d35737b68e74d9f237b80493eb53
|
||||||
@ -2059,8 +2059,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
|
|||||||
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
||||||
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
||||||
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
||||||
P 6d5dc9eed54b7d883aa7dbe2eb5ff17d2a703eabdb7d548a27cccc1fe5addb4a
|
P 861af465fda8485dfff143dc45c659b884d826aaec2ebaa941566404d1fe427b
|
||||||
R c32ff36f085986b819f258da8a8464b1
|
R 513d506718a1d19eb8b1625991fbf39f
|
||||||
U drh
|
U drh
|
||||||
Z f12a671d42ea42f2f1054a78088f03c4
|
Z 151ecb78555215509ebdea4705787b10
|
||||||
# Remove this line to create a well-formed Fossil manifest.
|
# Remove this line to create a well-formed Fossil manifest.
|
||||||
|
@ -1 +1 @@
|
|||||||
861af465fda8485dfff143dc45c659b884d826aaec2ebaa941566404d1fe427b
|
8036445a36d9d982c1305935e7e37367bdf9e466b923eb6286b52524802e3ccd
|
104
src/select.c
104
src/select.c
@ -2091,7 +2091,7 @@ void sqlite3GenerateColumnNames(
|
|||||||
if( pParse->colNamesSet ) return;
|
if( pParse->colNamesSet ) return;
|
||||||
/* Column names are determined by the left-most term of a compound select */
|
/* Column names are determined by the left-most term of a compound select */
|
||||||
while( pSelect->pPrior ) pSelect = pSelect->pPrior;
|
while( pSelect->pPrior ) pSelect = pSelect->pPrior;
|
||||||
SELECTTRACE(1,pParse,pSelect,("generating column names\n"));
|
TREETRACE(0x80,pParse,pSelect,("generating column names\n"));
|
||||||
pTabList = pSelect->pSrc;
|
pTabList = pSelect->pSrc;
|
||||||
pEList = pSelect->pEList;
|
pEList = pSelect->pEList;
|
||||||
assert( v!=0 );
|
assert( v!=0 );
|
||||||
@ -2877,7 +2877,7 @@ static int multiSelect(
|
|||||||
pPrior->iLimit = p->iLimit;
|
pPrior->iLimit = p->iLimit;
|
||||||
pPrior->iOffset = p->iOffset;
|
pPrior->iOffset = p->iOffset;
|
||||||
pPrior->pLimit = p->pLimit;
|
pPrior->pLimit = p->pLimit;
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect UNION ALL left...\n"));
|
TREETRACE(0x200, pParse, p, ("multiSelect UNION ALL left...\n"));
|
||||||
rc = sqlite3Select(pParse, pPrior, &dest);
|
rc = sqlite3Select(pParse, pPrior, &dest);
|
||||||
pPrior->pLimit = 0;
|
pPrior->pLimit = 0;
|
||||||
if( rc ){
|
if( rc ){
|
||||||
@ -2895,7 +2895,7 @@ static int multiSelect(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
ExplainQueryPlan((pParse, 1, "UNION ALL"));
|
ExplainQueryPlan((pParse, 1, "UNION ALL"));
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect UNION ALL right...\n"));
|
TREETRACE(0x200, pParse, p, ("multiSelect UNION ALL right...\n"));
|
||||||
rc = sqlite3Select(pParse, p, &dest);
|
rc = sqlite3Select(pParse, p, &dest);
|
||||||
testcase( rc!=SQLITE_OK );
|
testcase( rc!=SQLITE_OK );
|
||||||
pDelete = p->pPrior;
|
pDelete = p->pPrior;
|
||||||
@ -2948,7 +2948,7 @@ static int multiSelect(
|
|||||||
*/
|
*/
|
||||||
assert( !pPrior->pOrderBy );
|
assert( !pPrior->pOrderBy );
|
||||||
sqlite3SelectDestInit(&uniondest, priorOp, unionTab);
|
sqlite3SelectDestInit(&uniondest, priorOp, unionTab);
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect EXCEPT/UNION left...\n"));
|
TREETRACE(0x200, pParse, p, ("multiSelect EXCEPT/UNION left...\n"));
|
||||||
rc = sqlite3Select(pParse, pPrior, &uniondest);
|
rc = sqlite3Select(pParse, pPrior, &uniondest);
|
||||||
if( rc ){
|
if( rc ){
|
||||||
goto multi_select_end;
|
goto multi_select_end;
|
||||||
@ -2968,7 +2968,7 @@ static int multiSelect(
|
|||||||
uniondest.eDest = op;
|
uniondest.eDest = op;
|
||||||
ExplainQueryPlan((pParse, 1, "%s USING TEMP B-TREE",
|
ExplainQueryPlan((pParse, 1, "%s USING TEMP B-TREE",
|
||||||
sqlite3SelectOpName(p->op)));
|
sqlite3SelectOpName(p->op)));
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect EXCEPT/UNION right...\n"));
|
TREETRACE(0x200, pParse, p, ("multiSelect EXCEPT/UNION right...\n"));
|
||||||
rc = sqlite3Select(pParse, p, &uniondest);
|
rc = sqlite3Select(pParse, p, &uniondest);
|
||||||
testcase( rc!=SQLITE_OK );
|
testcase( rc!=SQLITE_OK );
|
||||||
assert( p->pOrderBy==0 );
|
assert( p->pOrderBy==0 );
|
||||||
@ -3029,7 +3029,7 @@ static int multiSelect(
|
|||||||
/* Code the SELECTs to our left into temporary table "tab1".
|
/* Code the SELECTs to our left into temporary table "tab1".
|
||||||
*/
|
*/
|
||||||
sqlite3SelectDestInit(&intersectdest, SRT_Union, tab1);
|
sqlite3SelectDestInit(&intersectdest, SRT_Union, tab1);
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect INTERSECT left...\n"));
|
TREETRACE(0x400, pParse, p, ("multiSelect INTERSECT left...\n"));
|
||||||
rc = sqlite3Select(pParse, pPrior, &intersectdest);
|
rc = sqlite3Select(pParse, pPrior, &intersectdest);
|
||||||
if( rc ){
|
if( rc ){
|
||||||
goto multi_select_end;
|
goto multi_select_end;
|
||||||
@ -3046,7 +3046,7 @@ static int multiSelect(
|
|||||||
intersectdest.iSDParm = tab2;
|
intersectdest.iSDParm = tab2;
|
||||||
ExplainQueryPlan((pParse, 1, "%s USING TEMP B-TREE",
|
ExplainQueryPlan((pParse, 1, "%s USING TEMP B-TREE",
|
||||||
sqlite3SelectOpName(p->op)));
|
sqlite3SelectOpName(p->op)));
|
||||||
SELECTTRACE(1, pParse, p, ("multiSelect INTERSECT right...\n"));
|
TREETRACE(0x400, pParse, p, ("multiSelect INTERSECT right...\n"));
|
||||||
rc = sqlite3Select(pParse, p, &intersectdest);
|
rc = sqlite3Select(pParse, p, &intersectdest);
|
||||||
testcase( rc!=SQLITE_OK );
|
testcase( rc!=SQLITE_OK );
|
||||||
pDelete = p->pPrior;
|
pDelete = p->pPrior;
|
||||||
@ -4395,7 +4395,7 @@ static int flattenSubquery(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/***** If we reach this point, flattening is permitted. *****/
|
/***** If we reach this point, flattening is permitted. *****/
|
||||||
SELECTTRACE(1,pParse,p,("flatten %u.%p from term %d\n",
|
TREETRACE(0x4,pParse,p,("flatten %u.%p from term %d\n",
|
||||||
pSub->selId, pSub, iFrom));
|
pSub->selId, pSub, iFrom));
|
||||||
|
|
||||||
/* Authorize the subquery */
|
/* Authorize the subquery */
|
||||||
@ -4474,7 +4474,7 @@ static int flattenSubquery(
|
|||||||
if( pPrior ) pPrior->pNext = pNew;
|
if( pPrior ) pPrior->pNext = pNew;
|
||||||
pNew->pNext = p;
|
pNew->pNext = p;
|
||||||
p->pPrior = pNew;
|
p->pPrior = pNew;
|
||||||
SELECTTRACE(2,pParse,p,("compound-subquery flattener"
|
TREETRACE(0x4,pParse,p,("compound-subquery flattener"
|
||||||
" creates %u as peer\n",pNew->selId));
|
" creates %u as peer\n",pNew->selId));
|
||||||
}
|
}
|
||||||
assert( pSubitem->pSelect==0 );
|
assert( pSubitem->pSelect==0 );
|
||||||
@ -4654,8 +4654,8 @@ static int flattenSubquery(
|
|||||||
sqlite3SelectDelete(db, pSub1);
|
sqlite3SelectDelete(db, pSub1);
|
||||||
|
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x100 ){
|
if( sqlite3TreeTrace & 0x4 ){
|
||||||
SELECTTRACE(0x100,pParse,p,("After flattening:\n"));
|
TREETRACE(0x4,pParse,p,("After flattening:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6068,8 +6068,8 @@ static int selectExpander(Walker *pWalker, Select *p){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x100 ){
|
if( sqlite3TreeTrace & 0x8 ){
|
||||||
SELECTTRACE(0x100,pParse,p,("After result-set wildcard expansion:\n"));
|
TREETRACE(0x8,pParse,p,("After result-set wildcard expansion:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6465,7 +6465,7 @@ static void havingToWhere(Parse *pParse, Select *p){
|
|||||||
sqlite3WalkExpr(&sWalker, p->pHaving);
|
sqlite3WalkExpr(&sWalker, p->pHaving);
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sWalker.eCode && (sqlite3TreeTrace & 0x100)!=0 ){
|
if( sWalker.eCode && (sqlite3TreeTrace & 0x100)!=0 ){
|
||||||
SELECTTRACE(0x100,pParse,p,("Move HAVING terms into WHERE:\n"));
|
TREETRACE(0x100,pParse,p,("Move HAVING terms into WHERE:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6597,8 +6597,8 @@ static int countOfViewOptimization(Parse *pParse, Select *p){
|
|||||||
p->selFlags &= ~SF_Aggregate;
|
p->selFlags &= ~SF_Aggregate;
|
||||||
|
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x400 ){
|
if( sqlite3TreeTrace & 0x200 ){
|
||||||
SELECTTRACE(0x400,pParse,p,("After count-of-view optimization:\n"));
|
TREETRACE(0x200,pParse,p,("After count-of-view optimization:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6698,8 +6698,8 @@ int sqlite3Select(
|
|||||||
assert( db->mallocFailed==0 );
|
assert( db->mallocFailed==0 );
|
||||||
if( sqlite3AuthCheck(pParse, SQLITE_SELECT, 0, 0, 0) ) return 1;
|
if( sqlite3AuthCheck(pParse, SQLITE_SELECT, 0, 0, 0) ) return 1;
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
SELECTTRACE(1,pParse,p, ("begin processing:\n", pParse->addrExplain));
|
TREETRACE(0x1,pParse,p, ("begin processing:\n", pParse->addrExplain));
|
||||||
if( sqlite3TreeTrace & 0x10100 ){
|
if( sqlite3TreeTrace & 0x10000 ){
|
||||||
if( (sqlite3TreeTrace & 0x10001)==0x10000 ){
|
if( (sqlite3TreeTrace & 0x10001)==0x10000 ){
|
||||||
sqlite3TreeViewLine(0, "In sqlite3Select() at %s:%d",
|
sqlite3TreeViewLine(0, "In sqlite3Select() at %s:%d",
|
||||||
__FILE__, __LINE__);
|
__FILE__, __LINE__);
|
||||||
@ -6719,8 +6719,8 @@ int sqlite3Select(
|
|||||||
/* All of these destinations are also able to ignore the ORDER BY clause */
|
/* All of these destinations are also able to ignore the ORDER BY clause */
|
||||||
if( p->pOrderBy ){
|
if( p->pOrderBy ){
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
SELECTTRACE(1,pParse,p, ("dropping superfluous ORDER BY:\n"));
|
TREETRACE(0x800,pParse,p, ("dropping superfluous ORDER BY:\n"));
|
||||||
if( sqlite3TreeTrace & 0x100 ){
|
if( sqlite3TreeTrace & 0x800 ){
|
||||||
sqlite3TreeViewExprList(0, p->pOrderBy, 0, "ORDERBY");
|
sqlite3TreeViewExprList(0, p->pOrderBy, 0, "ORDERBY");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6740,8 +6740,8 @@ int sqlite3Select(
|
|||||||
assert( db->mallocFailed==0 );
|
assert( db->mallocFailed==0 );
|
||||||
assert( p->pEList!=0 );
|
assert( p->pEList!=0 );
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x104 ){
|
if( sqlite3TreeTrace & 0x10 ){
|
||||||
SELECTTRACE(0x104,pParse,p, ("after name resolution:\n"));
|
TREETRACE(0x10,pParse,p, ("after name resolution:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6782,8 +6782,8 @@ int sqlite3Select(
|
|||||||
goto select_end;
|
goto select_end;
|
||||||
}
|
}
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( p->pWin && (sqlite3TreeTrace & 0x108)!=0 ){
|
if( p->pWin && (sqlite3TreeTrace & 0x40)!=0 ){
|
||||||
SELECTTRACE(0x104,pParse,p, ("after window rewrite:\n"));
|
TREETRACE(0x40,pParse,p, ("after window rewrite:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6814,7 +6814,7 @@ int sqlite3Select(
|
|||||||
&& sqlite3ExprImpliesNonNullRow(p->pWhere, pItem->iCursor)
|
&& sqlite3ExprImpliesNonNullRow(p->pWhere, pItem->iCursor)
|
||||||
&& OptimizationEnabled(db, SQLITE_SimplifyJoin)
|
&& OptimizationEnabled(db, SQLITE_SimplifyJoin)
|
||||||
){
|
){
|
||||||
SELECTTRACE(0x100,pParse,p,
|
TREETRACE(0x1000,pParse,p,
|
||||||
("LEFT-JOIN simplifies to JOIN on term %d\n",i));
|
("LEFT-JOIN simplifies to JOIN on term %d\n",i));
|
||||||
pItem->fg.jointype &= ~(JT_LEFT|JT_OUTER);
|
pItem->fg.jointype &= ~(JT_LEFT|JT_OUTER);
|
||||||
assert( pItem->iCursor>=0 );
|
assert( pItem->iCursor>=0 );
|
||||||
@ -6870,7 +6870,7 @@ int sqlite3Select(
|
|||||||
&& (p->selFlags & SF_OrderByReqd)==0 /* Condition (3) and (4) */
|
&& (p->selFlags & SF_OrderByReqd)==0 /* Condition (3) and (4) */
|
||||||
&& OptimizationEnabled(db, SQLITE_OmitOrderBy)
|
&& OptimizationEnabled(db, SQLITE_OmitOrderBy)
|
||||||
){
|
){
|
||||||
SELECTTRACE(0x100,pParse,p,
|
TREETRACE(0x800,pParse,p,
|
||||||
("omit superfluous ORDER BY on %r FROM-clause subquery\n",i+1));
|
("omit superfluous ORDER BY on %r FROM-clause subquery\n",i+1));
|
||||||
sqlite3ParserAddCleanup(pParse,
|
sqlite3ParserAddCleanup(pParse,
|
||||||
(void(*)(sqlite3*,void*))sqlite3ExprListDelete,
|
(void(*)(sqlite3*,void*))sqlite3ExprListDelete,
|
||||||
@ -6925,8 +6925,8 @@ int sqlite3Select(
|
|||||||
if( p->pPrior ){
|
if( p->pPrior ){
|
||||||
rc = multiSelect(pParse, p, pDest);
|
rc = multiSelect(pParse, p, pDest);
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
SELECTTRACE(0x1,pParse,p,("end compound-select processing\n"));
|
TREETRACE(0x400,pParse,p,("end compound-select processing\n"));
|
||||||
if( (sqlite3TreeTrace & 0x2000)!=0 && ExplainQueryPlanParent(pParse)==0 ){
|
if( (sqlite3TreeTrace & 0x400)!=0 && ExplainQueryPlanParent(pParse)==0 ){
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -6946,13 +6946,13 @@ int sqlite3Select(
|
|||||||
&& propagateConstants(pParse, p)
|
&& propagateConstants(pParse, p)
|
||||||
){
|
){
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x100 ){
|
if( sqlite3TreeTrace & 0x2000 ){
|
||||||
SELECTTRACE(0x100,pParse,p,("After constant propagation:\n"));
|
TREETRACE(0x2000,pParse,p,("After constant propagation:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}else{
|
}else{
|
||||||
SELECTTRACE(0x100,pParse,p,("Constant propagation not helpful\n"));
|
TREETRACE(0x2000,pParse,p,("Constant propagation not helpful\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SQLITE_COUNTOFVIEW_OPTIMIZATION
|
#ifdef SQLITE_COUNTOFVIEW_OPTIMIZATION
|
||||||
@ -7025,15 +7025,15 @@ int sqlite3Select(
|
|||||||
&& pushDownWhereTerms(pParse, pSub, p->pWhere, pItem)
|
&& pushDownWhereTerms(pParse, pSub, p->pWhere, pItem)
|
||||||
){
|
){
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x100 ){
|
if( sqlite3TreeTrace & 0x4000 ){
|
||||||
SELECTTRACE(0x100,pParse,p,
|
TREETRACE(0x4000,pParse,p,
|
||||||
("After WHERE-clause push-down into subquery %d:\n", pSub->selId));
|
("After WHERE-clause push-down into subquery %d:\n", pSub->selId));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
assert( pItem->pSelect && (pItem->pSelect->selFlags & SF_PushDown)!=0 );
|
assert( pItem->pSelect && (pItem->pSelect->selFlags & SF_PushDown)!=0 );
|
||||||
}else{
|
}else{
|
||||||
SELECTTRACE(0x100,pParse,p,("Push-down not possible\n"));
|
TREETRACE(0x4000,pParse,p,("Push-down not possible\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
zSavedAuthContext = pParse->zAuthContext;
|
zSavedAuthContext = pParse->zAuthContext;
|
||||||
@ -7148,8 +7148,8 @@ int sqlite3Select(
|
|||||||
sDistinct.isTnct = (p->selFlags & SF_Distinct)!=0;
|
sDistinct.isTnct = (p->selFlags & SF_Distinct)!=0;
|
||||||
|
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x400 ){
|
if( sqlite3TreeTrace & 0x8000 ){
|
||||||
SELECTTRACE(0x400,pParse,p,("After all FROM-clause analysis:\n"));
|
TREETRACE(0x8000,pParse,p,("After all FROM-clause analysis:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -7185,8 +7185,8 @@ int sqlite3Select(
|
|||||||
sDistinct.isTnct = 2;
|
sDistinct.isTnct = 2;
|
||||||
|
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x400 ){
|
if( sqlite3TreeTrace & 0x20000 ){
|
||||||
SELECTTRACE(0x400,pParse,p,("Transform DISTINCT into GROUP BY:\n"));
|
TREETRACE(0x20000,pParse,p,("Transform DISTINCT into GROUP BY:\n"));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -7272,7 +7272,7 @@ int sqlite3Select(
|
|||||||
|
|
||||||
|
|
||||||
/* Begin the database scan. */
|
/* Begin the database scan. */
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin\n"));
|
||||||
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, sSort.pOrderBy,
|
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, sSort.pOrderBy,
|
||||||
p->pEList, p, wctrlFlags, p->nSelectRow);
|
p->pEList, p, wctrlFlags, p->nSelectRow);
|
||||||
if( pWInfo==0 ) goto select_end;
|
if( pWInfo==0 ) goto select_end;
|
||||||
@ -7289,7 +7289,7 @@ int sqlite3Select(
|
|||||||
sSort.pOrderBy = 0;
|
sSort.pOrderBy = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin returns\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin returns\n"));
|
||||||
|
|
||||||
/* If sorting index that was created by a prior OP_OpenEphemeral
|
/* If sorting index that was created by a prior OP_OpenEphemeral
|
||||||
** instruction ended up not being needed, then change the OP_OpenEphemeral
|
** instruction ended up not being needed, then change the OP_OpenEphemeral
|
||||||
@ -7328,7 +7328,7 @@ int sqlite3Select(
|
|||||||
|
|
||||||
/* End the database scan loop.
|
/* End the database scan loop.
|
||||||
*/
|
*/
|
||||||
SELECTTRACE(1,pParse,p,("WhereEnd\n"));
|
TREETRACE(0x2,pParse,p,("WhereEnd\n"));
|
||||||
sqlite3WhereEnd(pWInfo);
|
sqlite3WhereEnd(pWInfo);
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
@ -7451,8 +7451,8 @@ int sqlite3Select(
|
|||||||
pAggInfo->mxReg = pParse->nMem;
|
pAggInfo->mxReg = pParse->nMem;
|
||||||
if( db->mallocFailed ) goto select_end;
|
if( db->mallocFailed ) goto select_end;
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
if( sqlite3TreeTrace & 0x400 ){
|
if( sqlite3TreeTrace & 0x20 ){
|
||||||
SELECTTRACE(0x400,pParse,p,("After aggregate analysis %p:\n", pAggInfo));
|
TREETRACE(0x20,pParse,p,("After aggregate analysis %p:\n", pAggInfo));
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
if( minMaxFlag ){
|
if( minMaxFlag ){
|
||||||
sqlite3DebugPrintf("MIN/MAX Optimization (0x%02x) adds:\n", minMaxFlag);
|
sqlite3DebugPrintf("MIN/MAX Optimization (0x%02x) adds:\n", minMaxFlag);
|
||||||
@ -7527,7 +7527,7 @@ int sqlite3Select(
|
|||||||
** in the right order to begin with.
|
** in the right order to begin with.
|
||||||
*/
|
*/
|
||||||
sqlite3VdbeAddOp2(v, OP_Gosub, regReset, addrReset);
|
sqlite3VdbeAddOp2(v, OP_Gosub, regReset, addrReset);
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin\n"));
|
||||||
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pGroupBy, pDistinct,
|
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pGroupBy, pDistinct,
|
||||||
p, (sDistinct.isTnct==2 ? WHERE_DISTINCTBY : WHERE_GROUPBY)
|
p, (sDistinct.isTnct==2 ? WHERE_DISTINCTBY : WHERE_GROUPBY)
|
||||||
| (orderByGrp ? WHERE_SORTBYGROUP : 0) | distFlag, 0
|
| (orderByGrp ? WHERE_SORTBYGROUP : 0) | distFlag, 0
|
||||||
@ -7537,7 +7537,7 @@ int sqlite3Select(
|
|||||||
goto select_end;
|
goto select_end;
|
||||||
}
|
}
|
||||||
eDist = sqlite3WhereIsDistinct(pWInfo);
|
eDist = sqlite3WhereIsDistinct(pWInfo);
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin returns\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin returns\n"));
|
||||||
if( sqlite3WhereIsOrdered(pWInfo)==pGroupBy->nExpr ){
|
if( sqlite3WhereIsOrdered(pWInfo)==pGroupBy->nExpr ){
|
||||||
/* The optimizer is able to deliver rows in group by order so
|
/* The optimizer is able to deliver rows in group by order so
|
||||||
** we do not have to sort. The OP_OpenEphemeral table will be
|
** we do not have to sort. The OP_OpenEphemeral table will be
|
||||||
@ -7586,7 +7586,7 @@ int sqlite3Select(
|
|||||||
sqlite3VdbeAddOp2(v, OP_SorterInsert, pAggInfo->sortingIdx, regRecord);
|
sqlite3VdbeAddOp2(v, OP_SorterInsert, pAggInfo->sortingIdx, regRecord);
|
||||||
sqlite3ReleaseTempReg(pParse, regRecord);
|
sqlite3ReleaseTempReg(pParse, regRecord);
|
||||||
sqlite3ReleaseTempRange(pParse, regBase, nCol);
|
sqlite3ReleaseTempRange(pParse, regBase, nCol);
|
||||||
SELECTTRACE(1,pParse,p,("WhereEnd\n"));
|
TREETRACE(0x2,pParse,p,("WhereEnd\n"));
|
||||||
sqlite3WhereEnd(pWInfo);
|
sqlite3WhereEnd(pWInfo);
|
||||||
pAggInfo->sortingIdxPTab = sortPTab = pParse->nTab++;
|
pAggInfo->sortingIdxPTab = sortPTab = pParse->nTab++;
|
||||||
sortOut = sqlite3GetTempReg(pParse);
|
sortOut = sqlite3GetTempReg(pParse);
|
||||||
@ -7664,7 +7664,7 @@ int sqlite3Select(
|
|||||||
sqlite3VdbeAddOp2(v, OP_SorterNext, pAggInfo->sortingIdx,addrTopOfLoop);
|
sqlite3VdbeAddOp2(v, OP_SorterNext, pAggInfo->sortingIdx,addrTopOfLoop);
|
||||||
VdbeCoverage(v);
|
VdbeCoverage(v);
|
||||||
}else{
|
}else{
|
||||||
SELECTTRACE(1,pParse,p,("WhereEnd\n"));
|
TREETRACE(0x2,pParse,p,("WhereEnd\n"));
|
||||||
sqlite3WhereEnd(pWInfo);
|
sqlite3WhereEnd(pWInfo);
|
||||||
sqlite3VdbeChangeToNoop(v, addrSortingIdx);
|
sqlite3VdbeChangeToNoop(v, addrSortingIdx);
|
||||||
}
|
}
|
||||||
@ -7826,13 +7826,13 @@ int sqlite3Select(
|
|||||||
assert( minMaxFlag==WHERE_ORDERBY_NORMAL || pMinMaxOrderBy!=0 );
|
assert( minMaxFlag==WHERE_ORDERBY_NORMAL || pMinMaxOrderBy!=0 );
|
||||||
assert( pMinMaxOrderBy==0 || pMinMaxOrderBy->nExpr==1 );
|
assert( pMinMaxOrderBy==0 || pMinMaxOrderBy->nExpr==1 );
|
||||||
|
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin\n"));
|
||||||
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pMinMaxOrderBy,
|
pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pMinMaxOrderBy,
|
||||||
pDistinct, p, minMaxFlag|distFlag, 0);
|
pDistinct, p, minMaxFlag|distFlag, 0);
|
||||||
if( pWInfo==0 ){
|
if( pWInfo==0 ){
|
||||||
goto select_end;
|
goto select_end;
|
||||||
}
|
}
|
||||||
SELECTTRACE(1,pParse,p,("WhereBegin returns\n"));
|
TREETRACE(0x2,pParse,p,("WhereBegin returns\n"));
|
||||||
eDist = sqlite3WhereIsDistinct(pWInfo);
|
eDist = sqlite3WhereIsDistinct(pWInfo);
|
||||||
updateAccumulator(pParse, regAcc, pAggInfo, eDist);
|
updateAccumulator(pParse, regAcc, pAggInfo, eDist);
|
||||||
if( eDist!=WHERE_DISTINCT_NOOP ){
|
if( eDist!=WHERE_DISTINCT_NOOP ){
|
||||||
@ -7846,7 +7846,7 @@ int sqlite3Select(
|
|||||||
if( minMaxFlag ){
|
if( minMaxFlag ){
|
||||||
sqlite3WhereMinMaxOptEarlyOut(v, pWInfo);
|
sqlite3WhereMinMaxOptEarlyOut(v, pWInfo);
|
||||||
}
|
}
|
||||||
SELECTTRACE(1,pParse,p,("WhereEnd\n"));
|
TREETRACE(0x2,pParse,p,("WhereEnd\n"));
|
||||||
sqlite3WhereEnd(pWInfo);
|
sqlite3WhereEnd(pWInfo);
|
||||||
finalizeAggFunctions(pParse, pAggInfo);
|
finalizeAggFunctions(pParse, pAggInfo);
|
||||||
}
|
}
|
||||||
@ -7907,8 +7907,8 @@ select_end:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if TREETRACE_ENABLED
|
#if TREETRACE_ENABLED
|
||||||
SELECTTRACE(0x1,pParse,p,("end processing\n"));
|
TREETRACE(0x1,pParse,p,("end processing\n"));
|
||||||
if( (sqlite3TreeTrace & 0x2000)!=0 && ExplainQueryPlanParent(pParse)==0 ){
|
if( (sqlite3TreeTrace & 0x40000)!=0 && ExplainQueryPlanParent(pParse)==0 ){
|
||||||
sqlite3TreeViewSelect(0, p, 0);
|
sqlite3TreeViewSelect(0, p, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -1029,12 +1029,12 @@ extern u32 sqlite3TreeTrace;
|
|||||||
&& (defined(SQLITE_TEST) || defined(SQLITE_ENABLE_SELECTTRACE) \
|
&& (defined(SQLITE_TEST) || defined(SQLITE_ENABLE_SELECTTRACE) \
|
||||||
|| defined(SQLITE_ENABLE_TREETRACE))
|
|| defined(SQLITE_ENABLE_TREETRACE))
|
||||||
# define TREETRACE_ENABLED 1
|
# define TREETRACE_ENABLED 1
|
||||||
# define SELECTTRACE(K,P,S,X) \
|
# define TREETRACE(K,P,S,X) \
|
||||||
if(sqlite3TreeTrace&(K)) \
|
if(sqlite3TreeTrace&(K)) \
|
||||||
sqlite3DebugPrintf("%u/%d/%p: ",(S)->selId,(P)->addrExplain,(S)),\
|
sqlite3DebugPrintf("%u/%d/%p: ",(S)->selId,(P)->addrExplain,(S)),\
|
||||||
sqlite3DebugPrintf X
|
sqlite3DebugPrintf X
|
||||||
#else
|
#else
|
||||||
# define SELECTTRACE(K,P,S,X)
|
# define TREETRACE(K,P,S,X)
|
||||||
# define TREETRACE_ENABLED 0
|
# define TREETRACE_ENABLED 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1069,7 +1069,7 @@ int sqlite3WindowRewrite(Parse *pParse, Select *p){
|
|||||||
pSub = sqlite3SelectNew(
|
pSub = sqlite3SelectNew(
|
||||||
pParse, pSublist, pSrc, pWhere, pGroupBy, pHaving, pSort, 0, 0
|
pParse, pSublist, pSrc, pWhere, pGroupBy, pHaving, pSort, 0, 0
|
||||||
);
|
);
|
||||||
SELECTTRACE(1,pParse,pSub,
|
TREETRACE(0x40,pParse,pSub,
|
||||||
("New window-function subquery in FROM clause of (%u/%p)\n",
|
("New window-function subquery in FROM clause of (%u/%p)\n",
|
||||||
p->selId, p));
|
p->selId, p));
|
||||||
p->pSrc = sqlite3SrcListAppend(pParse, 0, 0, 0);
|
p->pSrc = sqlite3SrcListAppend(pParse, 0, 0, 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user