-C Fix\sproblems\sin\sthe\sest_count\spragma\sfor\sindexes\sand\sWITHOUT\sROWID\stables.
-D 2016-10-21T15:36:51.551
+C Add\sthe\sbtree_sample(INDEX,LOCATION,LIMIT)\spragma.
+D 2016-10-21T17:25:47.070
F Makefile.in 6fd48ffcf7c2deea7499062d1f3747f986c19678
F Makefile.linux-gcc 7bc79876b875010e8c8f9502eb935ca92aa3c434
F Makefile.msc 5151cc64c4c05f3455f4f692ad11410a810d937f
F src/backup.c faf17e60b43233c214aae6a8179d24503a61e83b
F src/bitvec.c 3ee4c8b2c94ed3a7377256e18199e6ff5cf33f63
F src/btmutex.c bc87dd3b062cc26edfe79918de2200ccb8d41e73
-F src/btree.c c58b8a52ad8a74d48835a0471fadec0851d113fb
+F src/btree.c 955375bb1537dc16d9b59ad6fcfe31c5a140d1e3
F src/btree.h 012576c1d0000e96ccc785c6fe22b4be8211f0d9
F src/btreeInt.h c18b7d2a3494695133e4e60ee36061d37f45d9a5
F src/build.c e22e66fb34e1e50bb7869a510923bfe58db3071a
F src/pcache.c 5ff2a08f76a9c1b22f43eb063b7068fb085465ac
F src/pcache.h 2cedcd8407eb23017d92790b112186886e179490
F src/pcache1.c e3967219b2a92b9edcb9324a4ba75009090d3953
-F src/pragma.c e33c2c772e838402ff940eed581992a693a4a91a
-F src/pragma.h 30d6559672c6755be452ea5fdf2e9bf32acc69a3
+F src/pragma.c 3ef6e3168ed02ebc8247b3fc0d612b6fc6b0db24
+F src/pragma.h 74d46e32bdc7abb2d01710162ff96cfb483699b6
F src/prepare.c b1140c3d0cf59bc85ace00ce363153041b424b7a
F src/printf.c a5f0ca08ddede803c241266abb46356ec748ded1
F src/random.c ba2679f80ec82c4190062d756f22d0c358180696
F src/utf.c 699001c79f28e48e9bcdf8a463da029ea660540c
F src/util.c 3e2da6101888d073e79ecc6af5e0a2f70fa1e498
F src/vacuum.c 913970b9d86dd6c2b8063ef1af421880f1464ec3
-F src/vdbe.c c07f9a771c82619be14cc5368b19623ed8f3a30d
+F src/vdbe.c 55ea5eb95860106a8f665231f8d0c6b55dbf8974
F src/vdbe.h c044be7050ac6bf596eecc6ab159f5dbc020a3b7
F src/vdbeInt.h 0a18713d0a2fec6807d076bd333d9bf3e57530cd
F src/vdbeapi.c 8272f9342c39ab8d7eb4b9decc6caa7bc75b7d83
F tool/mkopcodec.tcl d1b6362bd3aa80d5520d4d6f3765badf01f6c43c
F tool/mkopcodeh.tcl a01d2c1d8a6205b03fc635adf3735b4c523befd3
F tool/mkopts.tcl 66ac10d240cc6e86abd37dc908d50382f84ff46e
-F tool/mkpragmatab.tcl bf6417cc44d42c1d024ac7036b59b9a8d4476470
+F tool/mkpragmatab.tcl c5ce5c56a8193196efcd195f09572a073445397f
F tool/mkspeedsql.tcl a1a334d288f7adfe6e996f2e712becf076745c97
F tool/mksqlite3c-noext.tcl fef88397668ae83166735c41af99d79f56afaabb
F tool/mksqlite3c.tcl 06b2e6a0f21cc0a5d70fbbd136b3e0a96470645e
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 340822afbe0c6b47fdd789c56acd9e1058a434cb
-R e90ad2ebf1bcb25a55e3e2678b19c035
+P c39fd9b8f11b3f1df489df1df4197fe4a670732c
+R 6376d702c2a44655952c143d8109c737
U drh
-Z 01c14e3ae29abee9ef7e5b8de3cc1480
+Z a6dc86cd66f951dc83fd16ce4ecf3406
-c39fd9b8f11b3f1df489df1df4197fe4a670732c
\ No newline at end of file
+affc2ef5ee3d8885e74051fd508a3d6f8c313857
\ No newline at end of file
}else{
perChild = mx/pPage->nCell;
rx = x/perChild;
+ if( rx>=pPage->nCell ) rx = pPage->nCell-1;
}
pCur->aiIdx[pCur->iPage] = rx;
+
return SQLITE_OK;
}
}
break;
+ /*
+ ** PRAGMA btree_sample(<table-or-index>,<fraction>,<limit>);
+ **
+ ** Seek in <table-or-index> through the first <fraction> of rows and
+ ** then begin returning rows, one by one. A max of <limit> rows will
+ ** be returned.
+ */
+ case PragTyp_BTREE_SAMPLE: {
+ Index *pIdx;
+ Table *pTab = 0;
+ Pgno iRoot = 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;
+ zName = pIdx->zName;
+ nCol = pIdx->nColumn;
+ }else if( (pTab = sqlite3FindTable(db, zRight, zDb))!=0 ){
+ zName = pTab->zName;
+ if( HasRowid(pTab) ){
+ iRoot = pTab->tnum;
+ nCol = pTab->nCol;
+ }else{
+ pIdx = sqlite3PrimaryKeyIndex(pTab);
+ iRoot = pIdx->tnum;
+ nCol = pIdx->nColumn;
+ }
+ }else{
+ break;
+ }
+ sqlite3VdbeSetNumCols(v, nCol);
+ for(i=0; i<nCol; i++){
+ char zCol[30];
+ sqlite3_snprintf(sizeof(zCol),zCol,"c%06d",i);
+ sqlite3VdbeSetColName(v, i, COLNAME_NAME, zCol, SQLITE_TRANSIENT);
+ }
+ 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;
+ if( pValues->nId>=3 ){
+ iLimit = sqlite3Atoi(pValues->a[2].zName);
+ }
+ pParse->nTab++;
+ sqlite3TableLock(pParse, iDb, iRoot, 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<nCol; i++){
+ sqlite3VdbeAddOp3(v, OP_Column, 0, i, regResult+i);
+ }
+ sqlite3VdbeAddOp2(v, OP_ResultRow, regResult, nCol);
+ addrJmp = sqlite3VdbeAddOp1(v, OP_DecrJumpZero, regLimit); VdbeCoverage(v);
+ sqlite3VdbeAddOp2(v, OP_Next, 0, addrTop); VdbeCoverage(v);
+ sqlite3VdbeJumpHere(v, addrJmp);
+ sqlite3VdbeJumpHere(v, addrSkip);
+ }
+ break;
+
#ifndef SQLITE_INTEGRITY_CHECK_ERROR_MAX
# define SQLITE_INTEGRITY_CHECK_ERROR_MAX 100
#endif
#define PragTyp_HEADER_VALUE 0
#define PragTyp_AUTO_VACUUM 1
#define PragTyp_FLAG 2
-#define PragTyp_BUSY_TIMEOUT 3
-#define PragTyp_CACHE_SIZE 4
-#define PragTyp_CACHE_SPILL 5
-#define PragTyp_CASE_SENSITIVE_LIKE 6
-#define PragTyp_COLLATION_LIST 7
-#define PragTyp_COMPILE_OPTIONS 8
-#define PragTyp_DATA_STORE_DIRECTORY 9
-#define PragTyp_DATABASE_LIST 10
-#define PragTyp_DEFAULT_CACHE_SIZE 11
-#define PragTyp_ENCODING 12
-#define PragTyp_EST_COUNT 13
-#define PragTyp_FOREIGN_KEY_CHECK 14
-#define PragTyp_FOREIGN_KEY_LIST 15
-#define PragTyp_INCREMENTAL_VACUUM 16
-#define PragTyp_INDEX_INFO 17
-#define PragTyp_INDEX_LIST 18
-#define PragTyp_INTEGRITY_CHECK 19
-#define PragTyp_JOURNAL_MODE 20
-#define PragTyp_JOURNAL_SIZE_LIMIT 21
-#define PragTyp_LOCK_PROXY_FILE 22
-#define PragTyp_LOCKING_MODE 23
-#define PragTyp_PAGE_COUNT 24
-#define PragTyp_MMAP_SIZE 25
-#define PragTyp_PAGE_SIZE 26
-#define PragTyp_SECURE_DELETE 27
-#define PragTyp_SHRINK_MEMORY 28
-#define PragTyp_SOFT_HEAP_LIMIT 29
-#define PragTyp_STATS 30
-#define PragTyp_SYNCHRONOUS 31
-#define PragTyp_TABLE_INFO 32
-#define PragTyp_TEMP_STORE 33
-#define PragTyp_TEMP_STORE_DIRECTORY 34
-#define PragTyp_THREADS 35
-#define PragTyp_WAL_AUTOCHECKPOINT 36
-#define PragTyp_WAL_CHECKPOINT 37
-#define PragTyp_ACTIVATE_EXTENSIONS 38
-#define PragTyp_HEXKEY 39
-#define PragTyp_KEY 40
-#define PragTyp_REKEY 41
-#define PragTyp_LOCK_STATUS 42
-#define PragTyp_PARSER_TRACE 43
+#define PragTyp_BTREE_SAMPLE 3
+#define PragTyp_BUSY_TIMEOUT 4
+#define PragTyp_CACHE_SIZE 5
+#define PragTyp_CACHE_SPILL 6
+#define PragTyp_CASE_SENSITIVE_LIKE 7
+#define PragTyp_COLLATION_LIST 8
+#define PragTyp_COMPILE_OPTIONS 9
+#define PragTyp_DATA_STORE_DIRECTORY 10
+#define PragTyp_DATABASE_LIST 11
+#define PragTyp_DEFAULT_CACHE_SIZE 12
+#define PragTyp_ENCODING 13
+#define PragTyp_EST_COUNT 14
+#define PragTyp_FOREIGN_KEY_CHECK 15
+#define PragTyp_FOREIGN_KEY_LIST 16
+#define PragTyp_INCREMENTAL_VACUUM 17
+#define PragTyp_INDEX_INFO 18
+#define PragTyp_INDEX_LIST 19
+#define PragTyp_INTEGRITY_CHECK 20
+#define PragTyp_JOURNAL_MODE 21
+#define PragTyp_JOURNAL_SIZE_LIMIT 22
+#define PragTyp_LOCK_PROXY_FILE 23
+#define PragTyp_LOCKING_MODE 24
+#define PragTyp_PAGE_COUNT 25
+#define PragTyp_MMAP_SIZE 26
+#define PragTyp_PAGE_SIZE 27
+#define PragTyp_SECURE_DELETE 28
+#define PragTyp_SHRINK_MEMORY 29
+#define PragTyp_SOFT_HEAP_LIMIT 30
+#define PragTyp_STATS 31
+#define PragTyp_SYNCHRONOUS 32
+#define PragTyp_TABLE_INFO 33
+#define PragTyp_TEMP_STORE 34
+#define PragTyp_TEMP_STORE_DIRECTORY 35
+#define PragTyp_THREADS 36
+#define PragTyp_WAL_AUTOCHECKPOINT 37
+#define PragTyp_WAL_CHECKPOINT 38
+#define PragTyp_ACTIVATE_EXTENSIONS 39
+#define PragTyp_HEXKEY 40
+#define PragTyp_KEY 41
+#define PragTyp_REKEY 42
+#define PragTyp_LOCK_STATUS 43
+#define PragTyp_PARSER_TRACE 44
#define PragFlag_NeedSchema 0x01
#define PragFlag_ReadOnly 0x02
static const struct sPragmaNames {
/* iArg: */ SQLITE_AutoIndex },
#endif
#endif
+ { /* zName: */ "btree_sample",
+ /* ePragTyp: */ PragTyp_BTREE_SAMPLE,
+ /* ePragFlag: */ PragFlag_NeedSchema,
+ /* iArg: */ 0 },
{ /* zName: */ "busy_timeout",
/* ePragTyp: */ PragTyp_BUSY_TIMEOUT,
/* ePragFlag: */ 0,
/* iArg: */ SQLITE_WriteSchema|SQLITE_RecoveryMode },
#endif
};
-/* Number of pragmas: 61 on by default, 74 total. */
+/* Number of pragmas: 62 on by default, 75 total. */
pOut = out2Prerelease(p, pOp);
pOut->flags = MEM_Real;
pOut->u.r = n;
+ pC->nullRow = 0;
+ pC->deferredMoveto = 0;
+ pC->cacheStatus = CACHE_STALE;
break;
}
NAME: est_count
FLAG: NeedSchema
+ NAME: btree_sample
+ FLAG: NeedSchema
+
NAME: encoding
IF: !defined(SQLITE_OMIT_UTF16)