-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
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
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
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;
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{
** 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