From: drh Date: Fri, 16 Dec 2016 16:49:11 +0000 (+0000) Subject: Experimental merge of the est_count_pragma and the pragma-as-vtab branches. X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=refs%2Fheads%2Fest-count-pragma-vtab;p=thirdparty%2Fsqlite.git Experimental merge of the est_count_pragma and the pragma-as-vtab branches. FossilOrigin-Name: 4b73ee33f31281886256663a0e4a6397d3c8efc5 --- 3cbb1995f364ac9644a08240726c8f8913e931cd diff --cc manifest index 4d0b8539bf,9f2f0544a0..eb6084f069 --- a/manifest +++ b/manifest @@@ -1,5 -1,5 +1,5 @@@ - C Fix\san\serror\sin\sthe\sway\sthe\s"schema"\sargument\sto\ssome\spragma\svirtual\stables\nis\shandled. - D 2016-12-16T04:20:27.559 -C Merge\srecent\strunk\senhancements. -D 2016-12-16T15:57:40.254 ++C Experimental\smerge\sof\sthe\sest_count_pragma\sand\sthe\spragma-as-vtab\sbranches. ++D 2016-12-16T16:49:11.848 F Makefile.in c194b58fe00c370a48ac6ae6945e92a7781db1c8 F Makefile.linux-gcc 7bc79876b875010e8c8f9502eb935ca92aa3c434 F Makefile.msc b8ca53350ae545e3562403d5da2a69cec79308da @@@ -331,10 -331,10 +331,10 @@@ F src/auth.c 930b376a9c56998557367e6f7f F src/backup.c faf17e60b43233c214aae6a8179d24503a61e83b F src/bitvec.c 17ea48eff8ba979f1f5b04cc484c7bb2be632f33 F src/btmutex.c bc87dd3b062cc26edfe79918de2200ccb8d41e73 - F src/btree.c b2055dff0b94e03eaad48a760984a2d8e39244e6 - F src/btree.h 2349a588abcd7e0c04f984e15c5c777b61637583 + F src/btree.c 7892be7e019565f6e5d2df6bda94befa7d91c9a0 + F src/btree.h 14931e081909f9b75009b0b5c5ead6b074204705 F src/btreeInt.h 10c4b77c2fb399580babbcc7cf652ac10dba796e - F src/build.c 52970b6cf3cf3107551a5d6dd668b0b261b0b491 -F src/build.c 182877f27be4129ffd385b80f3318251a605152b ++F src/build.c d814cb158ca2ef75c525e4c3f0d47b5666e53c95 F src/callback.c 2e76147783386374bf01b227f752c81ec872d730 F src/complete.c a3634ab1e687055cd002e11b8f43eb75c17da23e F src/ctime.c 9f2296a4e5d26ebf0e0d95a0af4628f1ea694e7a @@@ -381,8 -381,8 +381,8 @@@ F src/parse.y 5280d00e80f0fb118437ffc3f F src/pcache.c 51070ec9b8251bbf9c6ea3d35fd96a458752929e F src/pcache.h 2cedcd8407eb23017d92790b112186886e179490 F src/pcache1.c e3967219b2a92b9edcb9324a4ba75009090d3953 - F src/pragma.c d5adfe89ad7f3f45d4dbd25b96cbf3f6611aea2a - F src/pragma.h f9b221b2c8949ea941dbee49934299e4ed5af41c -F src/pragma.c 6ca8fb0a4da012c4ec4e92c76d868dca97ac6a03 -F src/pragma.h 74d46e32bdc7abb2d01710162ff96cfb483699b6 ++F src/pragma.c 850bee0057697e817c337c8141e12f74c64eb8f4 ++F src/pragma.h e2636093e33f5cc0feffc7ead45ce1268a5524e9 F src/prepare.c b1140c3d0cf59bc85ace00ce363153041b424b7a F src/printf.c f94da4935d1dd25420ac50c6745db1deb35e07c1 F src/random.c 80f5d666f23feb3e6665a6ce04c7197212a88384 @@@ -393,7 -393,7 +393,7 @@@ F src/shell.c f1c7fde7a83421e6ed620df41 F src/sqlite.h.in e8e2d108d82647f0a812fdb74accf91c1ec08ddc F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8 F src/sqlite3ext.h 8648034aa702469afb553231677306cc6492a1ae - F src/sqliteInt.h adbe80409c2926d91e5485789e5bf69313cd54b0 -F src/sqliteInt.h d4b1e6a694ed35bc669c9c99e0dea35e76e357f8 ++F src/sqliteInt.h 9f4111b5743fdb9d6dea6da81485abc94abf01ac F src/sqliteLimit.h c0373387c287c8d0932510b5547ecde31b5da247 F src/status.c a9e66593dfb28a9e746cba7153f84d49c1ddc4b1 F src/table.c 5226df15ab9179b9ed558d89575ea0ce37b03fc9 @@@ -1474,7 -1475,7 +1475,7 @@@ F tool/mkmsvcmin.tcl 2f12f7fa8858bbe61c F tool/mkopcodec.tcl d1b6362bd3aa80d5520d4d6f3765badf01f6c43c F tool/mkopcodeh.tcl a01d2c1d8a6205b03fc635adf3735b4c523befd3 F tool/mkopts.tcl 66ac10d240cc6e86abd37dc908d50382f84ff46e - F tool/mkpragmatab.tcl a30ee93515135466fc49ae881f75da07ebcafd19 -F tool/mkpragmatab.tcl c5ce5c56a8193196efcd195f09572a073445397f ++F tool/mkpragmatab.tcl c4e9c6b70e54e5720a81eeccfb4d739a566be217 F tool/mkspeedsql.tcl a1a334d288f7adfe6e996f2e712becf076745c97 F tool/mksqlite3c-noext.tcl fef88397668ae83166735c41af99d79f56afaabb F tool/mksqlite3c.tcl 06b2e6a0f21cc0a5d70fbbd136b3e0a96470645e @@@ -1536,7 -1537,7 +1537,10 @@@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a9 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0 - P 01afc515970a868c6a36d9a598453d0fde9e39ca - R a742a8093b3e07485d2949a360f59e06 -P dc006e08b80758b8ac3addd98a532b074b5ca132 053a149cc8244a7f85137129cfcb8622efe90306 -R 622e5a34bc63b8a2c15e428113c053e3 ++P 546821e29edb0282a4b1d8f49512e36027a6bf6d 74a0ca1f152d6d8454787557c6e990efe0e47a50 ++R 04f447c00e247ed4618fbb5b48ddcec6 ++T *branch * est-count-pragma-vtab ++T *sym-est-count-pragma-vtab * ++T -sym-pragma-as-vtab * U drh - Z b26c88cbc10f1352d564598308e683f5 -Z 935fedef2d7541845766cdea56b5f368 ++Z f94f7d33b2ad68dbdfa8be480e10347f diff --cc manifest.uuid index e8e79b2cfb,babbdd40c0..50c1300a4e --- a/manifest.uuid +++ b/manifest.uuid @@@ -1,1 -1,1 +1,1 @@@ - 546821e29edb0282a4b1d8f49512e36027a6bf6d -74a0ca1f152d6d8454787557c6e990efe0e47a50 ++4b73ee33f31281886256663a0e4a6397d3c8efc5 diff --cc src/pragma.c index d84e1d7929,e725b6cef0..4a024848d6 --- a/src/pragma.c +++ b/src/pragma.c @@@ -327,9 -305,9 +322,9 @@@ void sqlite3Pragma sqlite3 *db = pParse->db; /* The database connection */ Db *pDb; /* The specific database being pragmaed */ Vdbe *v = sqlite3GetVdbe(pParse); /* Prepared statement */ - const struct sPragmaNames *pPragma; + const PragmaName *pPragma; /* The pragma */ - if( v==0 ) return; + if( v==0 ) goto pragma_out; sqlite3VdbeRunOnlyOnce(v); pParse->nMem = 2; @@@ -1124,7 -1113,14 +1115,11 @@@ Index *pIdx; Table *pTab; pIdx = sqlite3FindIndex(db, zRight, zDb); + if( pIdx==0 ){ + pTab = sqlite3FindTable(db, zRight, zDb); + if( pTab && !HasRowid(pTab) ) pIdx = sqlite3PrimaryKeyIndex(pTab); + } if( pIdx ){ - static const char *azCol[] = { - "seqno", "cid", "name", "desc", "coll", "key" - }; int i; int mx; if( pPragma->iArg ){ @@@ -1370,6 -1385,135 +1365,133 @@@ } break; + /* + ** PRAGMA est_row_cnt(,); + ** + ** Seek in through the first of rows and + ** estimate the total number of rows based on the path back up to the + ** root. + */ + case PragTyp_EST_COUNT: { + Index *pIdx; + Table *pTab = 0; + Pgno iRoot = 0; + const char *zName = 0; + int regResult; + double r; - static const char *azCol[] = { "est" }; + if( (pIdx = sqlite3FindIndex(db, zRight, zDb))!=0 ){ + iRoot = pIdx->tnum; + zName = pIdx->zName; + }else if( (pTab = sqlite3FindTable(db, zRight, zDb))!=0 ){ + zName = pTab->zName; + if( HasRowid(pTab) ){ + iRoot = pTab->tnum; + }else{ + pIdx = sqlite3PrimaryKeyIndex(pTab); + iRoot = pIdx->tnum; + } + }else{ + break; + } + sqlite3TableLock(pParse, iDb, iRoot, 0, zName); + regResult = ++pParse->nMem; - setAllColumnNames(v, 1, azCol); + if( pValues->nId>=2 ){ + const char *z = pValues->a[1].zName; + sqlite3AtoF(z, &r, sqlite3Strlen30(z), SQLITE_UTF8); + }else{ + r = 0.5; + } + if( r<0.0 ) r = 0.0; + if( r>1.0 ) r = 1.0; + 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); + } + break; + + /* + ** PRAGMA btree_sample(,,); + ** + ** Seek in through the first of rows and + ** then begin returning rows, one by one. A max of rows will + ** be returned. + */ + case PragTyp_BTREE_SAMPLE: { + Index *pIdx; + Table *pTab = 0; + Pgno iRoot = 0; + Pgno iLock = 0; + int nCol = 0; + const char *zName = 0; + int iLimit = 10; + int i; + int regResult; + int regLimit; + int addrTop; + int addrJmp; + int addrSkip; + double r; + if( (pIdx = sqlite3FindIndex(db, zRight, zDb))!=0 ){ + iRoot = pIdx->tnum; + iLock = pIdx->pTable->tnum; + zName = pIdx->zName; + nCol = pIdx->nColumn; + }else if( (pTab = sqlite3FindTable(db, zRight, zDb))!=0 ){ + zName = pTab->zName; + if( HasRowid(pTab) ){ + iLock = iRoot = pTab->tnum; + nCol = pTab->nCol; + }else{ + pIdx = sqlite3PrimaryKeyIndex(pTab); + iLock = iRoot = pIdx->tnum; + nCol = pIdx->nColumn; + } + }else{ + break; + } + sqlite3VdbeSetNumCols(v, nCol); + for(i=0; inId>=2 ){ + const char *z = pValues->a[1].zName; + sqlite3AtoF(z, &r, sqlite3Strlen30(z), SQLITE_UTF8); + }else{ + r = 0.5; + } + if( r<0.0 ) r = 0.0; + if( r>1.0 ) r = 1.0; + if( pValues->nId>=3 ){ + iLimit = sqlite3Atoi(pValues->a[2].zName); + } + pParse->nTab++; + sqlite3TableLock(pParse, iDb, iLock, 0, zName); + sqlite3CodeVerifySchema(pParse, iDb); + sqlite3VdbeAddOp4Int(v, OP_OpenRead, 0, iRoot, iDb, nCol); + if( pIdx ) sqlite3VdbeSetP4KeyInfo(pParse, pIdx); + regLimit = ++pParse->nMem; + regResult = pParse->nMem+1; + pParse->nMem += nCol; + sqlite3VdbeAddOp2(v, OP_Integer, iLimit, regLimit); + addrSkip = sqlite3VdbeAddOp1(v, OP_Rewind, 0); VdbeCoverage(v); + sqlite3VdbeAddOp3(v, OP_EstRowCnt, 0, regResult, (int)(r*1000000000)); + addrTop = sqlite3VdbeCurrentAddr(v); + for(i=0; i