1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-11-19 21:43:15 +03:00

Update the NGQP to make use of STAT3 information if it is available.

FossilOrigin-Name: ff134e6ee95d41b0e59e03bba7e94bc15b04ff8c
This commit is contained in:
drh
2013-06-03 17:35:22 +00:00
parent 3b1d808fab
commit 6f2bfad24b
3 changed files with 33 additions and 10 deletions

View File

@@ -1,5 +1,5 @@
C Honor\sthe\sorderByConsumed\sboolean\sreturned\sfrom\svirtual\stable\squery\splanner.
D 2013-06-03T16:56:37.438
C Update\sthe\sNGQP\sto\smake\suse\sof\sSTAT3\sinformation\sif\sit\sis\savailable.
D 2013-06-03T17:35:22.501
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
F Makefile.in 5e41da95d92656a5004b03d3576e8b226858a28e
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -289,7 +289,7 @@ F src/vtab.c b05e5f1f4902461ba9f5fc49bb7eb7c3a0741a83
F src/wal.c 436bfceb141b9423c45119e68e444358ee0ed35d
F src/wal.h df01efe09c5cb8c8e391ff1715cca294f89668a4
F src/walker.c 4fa43583d0a84b48f93b1e88f11adf2065be4e73
F src/where.c 82c6fd16a6344108eac33642414958dc8db20d32
F src/where.c a60b27296226bc073ae87988f7cec222d9523d7d
F test/8_3_names.test ebbb5cd36741350040fd28b432ceadf495be25b2
F test/aggerror.test a867e273ef9e3d7919f03ef4f0e8c0d2767944f2
F test/aggnested.test 45c0201e28045ad38a530b5a144b73cd4aa2cfd6
@@ -1093,7 +1093,7 @@ F tool/vdbe-compress.tcl f12c884766bd14277f4fcedcae07078011717381
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
F tool/win/sqlite.vsix 97894c2790eda7b5bce3cc79cb2a8ec2fde9b3ac
P 62d382406b28c1347e13114f42215939ddfd7a9d
R 6374db7e82d972462ef1160c4988e05a
P aaf7f5896d3523531e1a9a1b90c4ad326f0c8fc7
R 821d5edba86d3e2ff0b1efea7de5e5d1
U drh
Z 8802671c91d46932119ceee1b71a0d50
Z 967f742fe27d5833ce434e13ad275aee

View File

@@ -1 +1 @@
aaf7f5896d3523531e1a9a1b90c4ad326f0c8fc7
ff134e6ee95d41b0e59e03bba7e94bc15b04ff8c

View File

@@ -3965,6 +3965,7 @@ static int whereLoopAddBtreeIndex(
int rc = SQLITE_OK; /* Return code */
tRowcnt iRowEst; /* Estimated index selectivity */
double rLogSize; /* Logarithm of table size */
WhereTerm *pTop, *pBtm; /* Top and bottom range constraints */
db = pBuilder->db;
pNew = pBuilder->pNew;
@@ -4031,12 +4032,35 @@ static int whereLoopAddBtreeIndex(
pNew->nOut = (double)iRowEst * nInMul;
}else if( pTerm->eOperator & (WO_GT|WO_GE) ){
pNew->wsFlags |= WHERE_COLUMN_RANGE|WHERE_BTM_LIMIT;
pNew->nOut = savedLoop.nOut/3;
pBtm = pTerm;
pTop = 0;
}else if( pTerm->eOperator & (WO_LT|WO_LE) ){
pNew->wsFlags |= WHERE_COLUMN_RANGE|WHERE_TOP_LIMIT;
pNew->nOut = savedLoop.nOut/3;
pTop = pTerm;
pBtm = (pNew->wsFlags & WHERE_BTM_LIMIT)!=0 ?
pNew->aTerm[pNew->nTerm-2] : 0;
}
pNew->rRun = rLogSize*nIn; /* Cost for nIn binary searches */
if( pNew->wsFlags & WHERE_COLUMN_RANGE ){
/* Adjust nOut and rRun for STAT3 range values */
double rDiv;
whereRangeScanEst(pBuilder->pParse, pProbe, pNew->u.btree.nEq,
pBtm, pTop, &rDiv);
pNew->nOut = savedLoop.nOut/rDiv;
}
#ifdef SQLITE_ENABLE_STAT3
if( pNew->u.btree.nEq==1 && pProbe->nSample ){
if( (pTerm->eOperator & (WO_EQ|WO_ISNULL))!=0 ){
rc = whereEqualScanEst(pBuilder->pParse, pProbe, pTerm->pExpr->pRight,
&pNew->nOut);
}else if( (pTerm->eOperator & WO_IN)
&& !ExprHasProperty(pTerm->pExpr, EP_xIsSelect) ){
rc = whereInScanEst(pBuilder->pParse, pProbe, pTerm->pExpr->x.pList,
&pNew->nOut);
}
}
#endif
if( pNew->wsFlags & (WHERE_IDX_ONLY|WHERE_IPK) ){
pNew->rRun += pNew->nOut; /* Unit step cost to reach each row */
}else{
@@ -4044,7 +4068,6 @@ static int whereLoopAddBtreeIndex(
** the main table */
pNew->rRun += pNew->nOut*(1 + rLogSize);
}
/* TBD: Adjust nOut and rRun for STAT3 range values */
/* TBD: Adjust nOut for additional constraints */
rc = whereLoopInsert(pBuilder, pNew);
if( (pNew->wsFlags & WHERE_TOP_LIMIT)==0