-C Experimental\sest_count\spragma.
-D 2016-10-20T22:02:43.512
+C Fix\sproblems\sin\sthe\sest_count\spragma\sfor\sindexes\sand\sWITHOUT\sROWID\stables.
+D 2016-10-21T15:36:51.551
F Makefile.in 6fd48ffcf7c2deea7499062d1f3747f986c19678
F Makefile.linux-gcc 7bc79876b875010e8c8f9502eb935ca92aa3c434
F Makefile.msc 5151cc64c4c05f3455f4f692ad11410a810d937f
F src/pcache.c 5ff2a08f76a9c1b22f43eb063b7068fb085465ac
F src/pcache.h 2cedcd8407eb23017d92790b112186886e179490
F src/pcache1.c e3967219b2a92b9edcb9324a4ba75009090d3953
-F src/pragma.c baf707463944a0788df1503e9920c36edca1fe8f
+F src/pragma.c e33c2c772e838402ff940eed581992a693a4a91a
F src/pragma.h 30d6559672c6755be452ea5fdf2e9bf32acc69a3
F src/prepare.c b1140c3d0cf59bc85ace00ce363153041b424b7a
F src/printf.c a5f0ca08ddede803c241266abb46356ec748ded1
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P fd81d8a4300c36d02f07371b722124ccf619654c
-R 43cd10c5c43a5cc4c174b3be405d48f3
-T *branch * est_count_pragma
-T *sym-est_count_pragma *
-T -sym-multi-arg-pragma *
+P 340822afbe0c6b47fdd789c56acd9e1058a434cb
+R e90ad2ebf1bcb25a55e3e2678b19c035
U drh
-Z 5a2d49857d0ed608295dc142049c4e6c
+Z 01c14e3ae29abee9ef7e5b8de3cc1480
*/
case PragTyp_EST_COUNT: {
Index *pIdx;
- Table *pTab;
+ Table *pTab = 0;
Pgno iRoot = 0;
const char *zName = 0;
int regResult;
iRoot = pIdx->tnum;
zName = pIdx->zName;
}else if( (pTab = sqlite3FindTable(db, zRight, zDb))!=0 ){
- iRoot = pTab->tnum;
zName = pTab->zName;
+ if( HasRowid(pTab) ){
+ iRoot = pTab->tnum;
+ }else{
+ pIdx = sqlite3PrimaryKeyIndex(pTab);
+ iRoot = pIdx->tnum;
+ }
}else{
break;
}
sqlite3CodeVerifySchema(pParse, iDb);
pParse->nTab++;
sqlite3VdbeAddOp4Int(v, OP_OpenRead, 0, iRoot, iDb, 1);
+ if( pIdx ) sqlite3VdbeSetP4KeyInfo(pParse, pIdx);
sqlite3VdbeAddOp3(v, OP_EstRowCnt, 0, regResult, (int)(r*1000000000));
sqlite3VdbeAddOp2(v, OP_ResultRow, regResult, 1);
}