4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 *************************************************************************
13 #include "sqlite3expert.h"
18 #if !defined(SQLITE_AMALGAMATION)
19 #if defined(SQLITE_COVERAGE_TEST) || defined(SQLITE_MUTATION_TEST)
20 # define SQLITE_OMIT_AUXILIARY_SAFETY_CHECKS 1
22 #if defined(SQLITE_OMIT_AUXILIARY_SAFETY_CHECKS)
23 # define ALWAYS(X) (1)
25 #elif !defined(NDEBUG)
26 # define ALWAYS(X) ((X)?1:(assert(0),0))
27 # define NEVER(X) ((X)?(assert(0),1):0)
29 # define ALWAYS(X) (X)
32 #endif /* !defined(SQLITE_AMALGAMATION) */
35 #ifndef SQLITE_OMIT_VIRTUALTABLE
37 typedef sqlite3_int64 i64
;
38 typedef sqlite3_uint64 u64
;
40 typedef struct IdxColumn IdxColumn
;
41 typedef struct IdxConstraint IdxConstraint
;
42 typedef struct IdxScan IdxScan
;
43 typedef struct IdxStatement IdxStatement
;
44 typedef struct IdxTable IdxTable
;
45 typedef struct IdxWrite IdxWrite
;
47 #define STRLEN (int)strlen
50 ** A temp table name that we assume no user database will actually use.
51 ** If this assumption proves incorrect triggers on the table with the
52 ** conflicting name will be ignored.
54 #define UNIQUE_TABLE_NAME "t592690916721053953805701627921227776"
57 ** A single constraint. Equivalent to either "col = ?" or "col < ?" (or
58 ** any other type of single-ended range constraint on a column).
61 ** Used to temporarily link IdxConstraint objects into lists while
62 ** creating candidate indexes.
64 struct IdxConstraint
{
65 char *zColl
; /* Collation sequence */
66 int bRange
; /* True for range, false for eq */
67 int iCol
; /* Constrained table column */
68 int bFlag
; /* Used by idxFindCompatible() */
69 int bDesc
; /* True if ORDER BY <expr> DESC */
70 IdxConstraint
*pNext
; /* Next constraint in pEq or pRange list */
71 IdxConstraint
*pLink
; /* See above */
75 ** A single scan of a single table.
78 IdxTable
*pTab
; /* Associated table object */
79 int iDb
; /* Database containing table zTable */
80 i64 covering
; /* Mask of columns required for cov. index */
81 IdxConstraint
*pOrder
; /* ORDER BY columns */
82 IdxConstraint
*pEq
; /* List of == constraints */
83 IdxConstraint
*pRange
; /* List of < constraints */
84 IdxScan
*pNextScan
; /* Next IdxScan object for same analysis */
88 ** Information regarding a single database table. Extracted from
89 ** "PRAGMA table_info" by function idxGetTableInfo().
98 char *zName
; /* Table name */
100 IdxTable
*pNext
; /* Next table in linked list of all tables */
104 ** An object of the following type is created for each unique table/write-op
105 ** seen. The objects are stored in a singly-linked list beginning at
106 ** sqlite3expert.pWrite.
110 int eOp
; /* SQLITE_UPDATE, DELETE or INSERT */
115 ** Each statement being analyzed is represented by an instance of this
118 struct IdxStatement
{
119 int iId
; /* Statement number */
120 char *zSql
; /* SQL statement */
121 char *zIdx
; /* Indexes */
122 char *zEQP
; /* Plan */
128 ** A hash table for storing strings. With space for a payload string
129 ** with each entry. Methods are:
136 #define IDX_HASH_SIZE 1023
137 typedef struct IdxHashEntry IdxHashEntry
;
138 typedef struct IdxHash IdxHash
;
139 struct IdxHashEntry
{
140 char *zKey
; /* nul-terminated key */
141 char *zVal
; /* nul-terminated value string */
142 char *zVal2
; /* nul-terminated value string 2 */
143 IdxHashEntry
*pHashNext
; /* Next entry in same hash bucket */
144 IdxHashEntry
*pNext
; /* Next entry in hash */
147 IdxHashEntry
*pFirst
;
148 IdxHashEntry
*aHash
[IDX_HASH_SIZE
];
152 ** sqlite3expert object.
154 struct sqlite3expert
{
155 int iSample
; /* Percentage of tables to sample for stat1 */
156 sqlite3
*db
; /* User database */
157 sqlite3
*dbm
; /* In-memory db for this analysis */
158 sqlite3
*dbv
; /* Vtab schema for this analysis */
159 IdxTable
*pTable
; /* List of all IdxTable objects */
160 IdxScan
*pScan
; /* List of scan objects */
161 IdxWrite
*pWrite
; /* List of write objects */
162 IdxStatement
*pStatement
; /* List of IdxStatement objects */
163 int bRun
; /* True once analysis has run */
165 int rc
; /* Error code from whereinfo hook */
166 IdxHash hIdx
; /* Hash containing all candidate indexes */
167 char *zCandidates
; /* For EXPERT_REPORT_CANDIDATES */
172 ** Allocate and return nByte bytes of zeroed memory using sqlite3_malloc().
173 ** If the allocation fails, set *pRc to SQLITE_NOMEM and return NULL.
175 static void *idxMalloc(int *pRc
, int nByte
){
177 assert( *pRc
==SQLITE_OK
);
179 pRet
= sqlite3_malloc(nByte
);
181 memset(pRet
, 0, nByte
);
189 ** Initialize an IdxHash hash table.
191 static void idxHashInit(IdxHash
*pHash
){
192 memset(pHash
, 0, sizeof(IdxHash
));
196 ** Reset an IdxHash hash table.
198 static void idxHashClear(IdxHash
*pHash
){
200 for(i
=0; i
<IDX_HASH_SIZE
; i
++){
201 IdxHashEntry
*pEntry
;
203 for(pEntry
=pHash
->aHash
[i
]; pEntry
; pEntry
=pNext
){
204 pNext
= pEntry
->pHashNext
;
205 sqlite3_free(pEntry
->zVal2
);
206 sqlite3_free(pEntry
);
209 memset(pHash
, 0, sizeof(IdxHash
));
213 ** Return the index of the hash bucket that the string specified by the
214 ** arguments to this function belongs.
216 static int idxHashString(const char *z
, int n
){
217 unsigned int ret
= 0;
220 ret
+= (ret
<<3) + (unsigned char)(z
[i
]);
222 return (int)(ret
% IDX_HASH_SIZE
);
226 ** If zKey is already present in the hash table, return non-zero and do
227 ** nothing. Otherwise, add an entry with key zKey and payload string zVal to
228 ** the hash table passed as the second argument.
230 static int idxHashAdd(
236 int nKey
= STRLEN(zKey
);
237 int iHash
= idxHashString(zKey
, nKey
);
238 int nVal
= (zVal
? STRLEN(zVal
) : 0);
239 IdxHashEntry
*pEntry
;
241 for(pEntry
=pHash
->aHash
[iHash
]; pEntry
; pEntry
=pEntry
->pHashNext
){
242 if( STRLEN(pEntry
->zKey
)==nKey
&& 0==memcmp(pEntry
->zKey
, zKey
, nKey
) ){
246 pEntry
= idxMalloc(pRc
, sizeof(IdxHashEntry
) + nKey
+1 + nVal
+1);
248 pEntry
->zKey
= (char*)&pEntry
[1];
249 memcpy(pEntry
->zKey
, zKey
, nKey
);
251 pEntry
->zVal
= &pEntry
->zKey
[nKey
+1];
252 memcpy(pEntry
->zVal
, zVal
, nVal
);
254 pEntry
->pHashNext
= pHash
->aHash
[iHash
];
255 pHash
->aHash
[iHash
] = pEntry
;
257 pEntry
->pNext
= pHash
->pFirst
;
258 pHash
->pFirst
= pEntry
;
264 ** If zKey/nKey is present in the hash table, return a pointer to the
265 ** hash-entry object.
267 static IdxHashEntry
*idxHashFind(IdxHash
*pHash
, const char *zKey
, int nKey
){
269 IdxHashEntry
*pEntry
;
270 if( nKey
<0 ) nKey
= STRLEN(zKey
);
271 iHash
= idxHashString(zKey
, nKey
);
273 for(pEntry
=pHash
->aHash
[iHash
]; pEntry
; pEntry
=pEntry
->pHashNext
){
274 if( STRLEN(pEntry
->zKey
)==nKey
&& 0==memcmp(pEntry
->zKey
, zKey
, nKey
) ){
282 ** If the hash table contains an entry with a key equal to the string
283 ** passed as the final two arguments to this function, return a pointer
284 ** to the payload string. Otherwise, if zKey/nKey is not present in the
285 ** hash table, return NULL.
287 static const char *idxHashSearch(IdxHash
*pHash
, const char *zKey
, int nKey
){
288 IdxHashEntry
*pEntry
= idxHashFind(pHash
, zKey
, nKey
);
289 if( pEntry
) return pEntry
->zVal
;
294 ** Allocate and return a new IdxConstraint object. Set the IdxConstraint.zColl
295 ** variable to point to a copy of nul-terminated string zColl.
297 static IdxConstraint
*idxNewConstraint(int *pRc
, const char *zColl
){
299 int nColl
= STRLEN(zColl
);
301 assert( *pRc
==SQLITE_OK
);
302 pNew
= (IdxConstraint
*)idxMalloc(pRc
, sizeof(IdxConstraint
) * nColl
+ 1);
304 pNew
->zColl
= (char*)&pNew
[1];
305 memcpy(pNew
->zColl
, zColl
, nColl
+1);
311 ** An error associated with database handle db has just occurred. Pass
312 ** the error message to callback function xOut.
314 static void idxDatabaseError(
315 sqlite3
*db
, /* Database handle */
316 char **pzErrmsg
/* Write error here */
318 *pzErrmsg
= sqlite3_mprintf("%s", sqlite3_errmsg(db
));
322 ** Prepare an SQL statement.
324 static int idxPrepareStmt(
325 sqlite3
*db
, /* Database handle to compile against */
326 sqlite3_stmt
**ppStmt
, /* OUT: Compiled SQL statement */
327 char **pzErrmsg
, /* OUT: sqlite3_malloc()ed error message */
328 const char *zSql
/* SQL statement to compile */
330 int rc
= sqlite3_prepare_v2(db
, zSql
, -1, ppStmt
, 0);
333 idxDatabaseError(db
, pzErrmsg
);
339 ** Prepare an SQL statement using the results of a printf() formatting.
341 static int idxPrintfPrepareStmt(
342 sqlite3
*db
, /* Database handle to compile against */
343 sqlite3_stmt
**ppStmt
, /* OUT: Compiled SQL statement */
344 char **pzErrmsg
, /* OUT: sqlite3_malloc()ed error message */
345 const char *zFmt
, /* printf() format of SQL statement */
346 ... /* Trailing printf() arguments */
352 zSql
= sqlite3_vmprintf(zFmt
, ap
);
356 rc
= idxPrepareStmt(db
, ppStmt
, pzErrmsg
, zSql
);
364 /*************************************************************************
365 ** Beginning of virtual table implementation.
367 typedef struct ExpertVtab ExpertVtab
;
371 sqlite3expert
*pExpert
;
374 typedef struct ExpertCsr ExpertCsr
;
376 sqlite3_vtab_cursor base
;
380 static char *expertDequote(const char *zIn
){
382 char *zRet
= sqlite3_malloc(n
);
384 assert( zIn
[0]=='\'' );
385 assert( zIn
[n
-1]=='\'' );
390 for(iIn
=1; iIn
<(n
-1); iIn
++){
391 if( zIn
[iIn
]=='\'' ){
392 assert( zIn
[iIn
+1]=='\'' );
395 zRet
[iOut
++] = zIn
[iIn
];
404 ** This function is the implementation of both the xConnect and xCreate
405 ** methods of the r-tree virtual table.
407 ** argv[0] -> module name
408 ** argv[1] -> database name
409 ** argv[2] -> table name
410 ** argv[...] -> column names...
412 static int expertConnect(
415 int argc
, const char *const*argv
,
416 sqlite3_vtab
**ppVtab
,
419 sqlite3expert
*pExpert
= (sqlite3expert
*)pAux
;
424 *pzErr
= sqlite3_mprintf("internal error!");
427 char *zCreateTable
= expertDequote(argv
[3]);
429 rc
= sqlite3_declare_vtab(db
, zCreateTable
);
431 p
= idxMalloc(&rc
, sizeof(ExpertVtab
));
434 p
->pExpert
= pExpert
;
435 p
->pTab
= pExpert
->pTable
;
436 assert( sqlite3_stricmp(p
->pTab
->zName
, argv
[2])==0 );
438 sqlite3_free(zCreateTable
);
444 *ppVtab
= (sqlite3_vtab
*)p
;
448 static int expertDisconnect(sqlite3_vtab
*pVtab
){
449 ExpertVtab
*p
= (ExpertVtab
*)pVtab
;
454 static int expertBestIndex(sqlite3_vtab
*pVtab
, sqlite3_index_info
*pIdxInfo
){
455 ExpertVtab
*p
= (ExpertVtab
*)pVtab
;
460 SQLITE_INDEX_CONSTRAINT_EQ
| SQLITE_INDEX_CONSTRAINT_GT
|
461 SQLITE_INDEX_CONSTRAINT_LT
| SQLITE_INDEX_CONSTRAINT_GE
|
462 SQLITE_INDEX_CONSTRAINT_LE
;
464 pScan
= idxMalloc(&rc
, sizeof(IdxScan
));
468 /* Link the new scan object into the list */
469 pScan
->pTab
= p
->pTab
;
470 pScan
->pNextScan
= p
->pExpert
->pScan
;
471 p
->pExpert
->pScan
= pScan
;
473 /* Add the constraints to the IdxScan object */
474 for(i
=0; i
<pIdxInfo
->nConstraint
; i
++){
475 struct sqlite3_index_constraint
*pCons
= &pIdxInfo
->aConstraint
[i
];
478 && p
->pTab
->aCol
[pCons
->iColumn
].iPk
==0
479 && (pCons
->op
& opmask
)
482 const char *zColl
= sqlite3_vtab_collation(pIdxInfo
, i
);
483 pNew
= idxNewConstraint(&rc
, zColl
);
485 pNew
->iCol
= pCons
->iColumn
;
486 if( pCons
->op
==SQLITE_INDEX_CONSTRAINT_EQ
){
487 pNew
->pNext
= pScan
->pEq
;
491 pNew
->pNext
= pScan
->pRange
;
492 pScan
->pRange
= pNew
;
496 pIdxInfo
->aConstraintUsage
[i
].argvIndex
= n
;
500 /* Add the ORDER BY to the IdxScan object */
501 for(i
=pIdxInfo
->nOrderBy
-1; i
>=0; i
--){
502 int iCol
= pIdxInfo
->aOrderBy
[i
].iColumn
;
504 IdxConstraint
*pNew
= idxNewConstraint(&rc
, p
->pTab
->aCol
[iCol
].zColl
);
507 pNew
->bDesc
= pIdxInfo
->aOrderBy
[i
].desc
;
508 pNew
->pNext
= pScan
->pOrder
;
509 pNew
->pLink
= pScan
->pOrder
;
510 pScan
->pOrder
= pNew
;
517 pIdxInfo
->estimatedCost
= 1000000.0 / (n
+1);
521 static int expertUpdate(
524 sqlite3_value
**azData
,
535 ** Virtual table module xOpen method.
537 static int expertOpen(sqlite3_vtab
*pVTab
, sqlite3_vtab_cursor
**ppCursor
){
541 pCsr
= idxMalloc(&rc
, sizeof(ExpertCsr
));
542 *ppCursor
= (sqlite3_vtab_cursor
*)pCsr
;
547 ** Virtual table module xClose method.
549 static int expertClose(sqlite3_vtab_cursor
*cur
){
550 ExpertCsr
*pCsr
= (ExpertCsr
*)cur
;
551 sqlite3_finalize(pCsr
->pData
);
557 ** Virtual table module xEof method.
559 ** Return non-zero if the cursor does not currently point to a valid
560 ** record (i.e if the scan has finished), or zero otherwise.
562 static int expertEof(sqlite3_vtab_cursor
*cur
){
563 ExpertCsr
*pCsr
= (ExpertCsr
*)cur
;
564 return pCsr
->pData
==0;
568 ** Virtual table module xNext method.
570 static int expertNext(sqlite3_vtab_cursor
*cur
){
571 ExpertCsr
*pCsr
= (ExpertCsr
*)cur
;
574 assert( pCsr
->pData
);
575 rc
= sqlite3_step(pCsr
->pData
);
576 if( rc
!=SQLITE_ROW
){
577 rc
= sqlite3_finalize(pCsr
->pData
);
587 ** Virtual table module xRowid method.
589 static int expertRowid(sqlite3_vtab_cursor
*cur
, sqlite_int64
*pRowid
){
596 ** Virtual table module xColumn method.
598 static int expertColumn(sqlite3_vtab_cursor
*cur
, sqlite3_context
*ctx
, int i
){
599 ExpertCsr
*pCsr
= (ExpertCsr
*)cur
;
601 pVal
= sqlite3_column_value(pCsr
->pData
, i
);
603 sqlite3_result_value(ctx
, pVal
);
609 ** Virtual table module xFilter method.
611 static int expertFilter(
612 sqlite3_vtab_cursor
*cur
,
613 int idxNum
, const char *idxStr
,
614 int argc
, sqlite3_value
**argv
616 ExpertCsr
*pCsr
= (ExpertCsr
*)cur
;
617 ExpertVtab
*pVtab
= (ExpertVtab
*)(cur
->pVtab
);
618 sqlite3expert
*pExpert
= pVtab
->pExpert
;
625 rc
= sqlite3_finalize(pCsr
->pData
);
628 rc
= idxPrintfPrepareStmt(pExpert
->db
, &pCsr
->pData
, &pVtab
->base
.zErrMsg
,
629 "SELECT * FROM main.%Q WHERE sqlite_expert_sample()", pVtab
->pTab
->zName
634 rc
= expertNext(cur
);
639 static int idxRegisterVtab(sqlite3expert
*p
){
640 static sqlite3_module expertModule
= {
642 expertConnect
, /* xCreate - create a table */
643 expertConnect
, /* xConnect - connect to an existing table */
644 expertBestIndex
, /* xBestIndex - Determine search strategy */
645 expertDisconnect
, /* xDisconnect - Disconnect from a table */
646 expertDisconnect
, /* xDestroy - Drop a table */
647 expertOpen
, /* xOpen - open a cursor */
648 expertClose
, /* xClose - close a cursor */
649 expertFilter
, /* xFilter - configure scan constraints */
650 expertNext
, /* xNext - advance a cursor */
651 expertEof
, /* xEof */
652 expertColumn
, /* xColumn - read data */
653 expertRowid
, /* xRowid - read data */
654 expertUpdate
, /* xUpdate - write data */
655 0, /* xBegin - begin transaction */
656 0, /* xSync - sync transaction */
657 0, /* xCommit - commit transaction */
658 0, /* xRollback - rollback transaction */
659 0, /* xFindFunction - function overloading */
660 0, /* xRename - rename the table */
668 return sqlite3_create_module(p
->dbv
, "expert", &expertModule
, (void*)p
);
671 ** End of virtual table implementation.
672 *************************************************************************/
674 ** Finalize SQL statement pStmt. If (*pRc) is SQLITE_OK when this function
675 ** is called, set it to the return value of sqlite3_finalize() before
676 ** returning. Otherwise, discard the sqlite3_finalize() return value.
678 static void idxFinalize(int *pRc
, sqlite3_stmt
*pStmt
){
679 int rc
= sqlite3_finalize(pStmt
);
680 if( *pRc
==SQLITE_OK
) *pRc
= rc
;
684 ** Attempt to allocate an IdxTable structure corresponding to table zTab
685 ** in the main database of connection db. If successful, set (*ppOut) to
686 ** point to the new object and return SQLITE_OK. Otherwise, return an
687 ** SQLite error code and set (*ppOut) to NULL. In this case *pzErrmsg may be
688 ** set to point to an error string.
690 ** It is the responsibility of the caller to eventually free either the
691 ** IdxTable object or error message using sqlite3_free().
693 static int idxGetTableInfo(
694 sqlite3
*db
, /* Database connection to read details from */
695 const char *zTab
, /* Table name */
696 IdxTable
**ppOut
, /* OUT: New object (if successful) */
697 char **pzErrmsg
/* OUT: Error message (if not) */
699 sqlite3_stmt
*p1
= 0;
709 if( zTab
==0 ) return SQLITE_ERROR
;
711 nByte
= sizeof(IdxTable
) + nTab
+ 1;
712 rc
= idxPrintfPrepareStmt(db
, &p1
, pzErrmsg
, "PRAGMA table_xinfo=%Q", zTab
);
713 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(p1
) ){
714 const char *zCol
= (const char*)sqlite3_column_text(p1
, 1);
715 const char *zColSeq
= 0;
720 nByte
+= 1 + STRLEN(zCol
);
721 rc
= sqlite3_table_column_metadata(
722 db
, "main", zTab
, zCol
, 0, &zColSeq
, 0, 0, 0
724 if( zColSeq
==0 ) zColSeq
= "binary";
725 nByte
+= 1 + STRLEN(zColSeq
);
727 nPk
+= (sqlite3_column_int(p1
, 5)>0);
729 rc2
= sqlite3_reset(p1
);
730 if( rc
==SQLITE_OK
) rc
= rc2
;
732 nByte
+= sizeof(IdxColumn
) * nCol
;
734 pNew
= idxMalloc(&rc
, nByte
);
737 pNew
->aCol
= (IdxColumn
*)&pNew
[1];
739 pCsr
= (char*)&pNew
->aCol
[nCol
];
743 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(p1
) ){
744 const char *zCol
= (const char*)sqlite3_column_text(p1
, 1);
745 const char *zColSeq
= 0;
747 if( zCol
==0 ) continue;
748 nCopy
= STRLEN(zCol
) + 1;
749 pNew
->aCol
[nCol
].zName
= pCsr
;
750 pNew
->aCol
[nCol
].iPk
= (sqlite3_column_int(p1
, 5)==1 && nPk
==1);
751 memcpy(pCsr
, zCol
, nCopy
);
754 rc
= sqlite3_table_column_metadata(
755 db
, "main", zTab
, zCol
, 0, &zColSeq
, 0, 0, 0
758 if( zColSeq
==0 ) zColSeq
= "binary";
759 nCopy
= STRLEN(zColSeq
) + 1;
760 pNew
->aCol
[nCol
].zColl
= pCsr
;
761 memcpy(pCsr
, zColSeq
, nCopy
);
767 idxFinalize(&rc
, p1
);
772 }else if( ALWAYS(pNew
!=0) ){
774 if( ALWAYS(pNew
->zName
!=0) ) memcpy(pNew
->zName
, zTab
, nTab
+1);
782 ** This function is a no-op if *pRc is set to anything other than
783 ** SQLITE_OK when it is called.
785 ** If *pRc is initially set to SQLITE_OK, then the text specified by
786 ** the printf() style arguments is appended to zIn and the result returned
787 ** in a buffer allocated by sqlite3_malloc(). sqlite3_free() is called on
788 ** zIn before returning.
790 static char *idxAppendText(int *pRc
, char *zIn
, const char *zFmt
, ...){
794 int nIn
= zIn
? STRLEN(zIn
) : 0;
797 if( *pRc
==SQLITE_OK
){
798 zAppend
= sqlite3_vmprintf(zFmt
, ap
);
800 nAppend
= STRLEN(zAppend
);
801 zRet
= (char*)sqlite3_malloc(nIn
+ nAppend
+ 1);
803 if( zAppend
&& zRet
){
804 if( nIn
) memcpy(zRet
, zIn
, nIn
);
805 memcpy(&zRet
[nIn
], zAppend
, nAppend
+1);
811 sqlite3_free(zAppend
);
819 ** Return true if zId must be quoted in order to use it as an SQL
820 ** identifier, or false otherwise.
822 static int idxIdentifierRequiresQuotes(const char *zId
){
824 int nId
= STRLEN(zId
);
826 if( sqlite3_keyword_check(zId
, nId
) ) return 1;
828 for(i
=0; zId
[i
]; i
++){
830 && !(zId
[i
]>='0' && zId
[i
]<='9')
831 && !(zId
[i
]>='a' && zId
[i
]<='z')
832 && !(zId
[i
]>='A' && zId
[i
]<='Z')
841 ** This function appends an index column definition suitable for constraint
842 ** pCons to the string passed as zIn and returns the result.
844 static char *idxAppendColDefn(
845 int *pRc
, /* IN/OUT: Error code */
846 char *zIn
, /* Column defn accumulated so far */
847 IdxTable
*pTab
, /* Table index will be created on */
851 IdxColumn
*p
= &pTab
->aCol
[pCons
->iCol
];
852 if( zRet
) zRet
= idxAppendText(pRc
, zRet
, ", ");
854 if( idxIdentifierRequiresQuotes(p
->zName
) ){
855 zRet
= idxAppendText(pRc
, zRet
, "%Q", p
->zName
);
857 zRet
= idxAppendText(pRc
, zRet
, "%s", p
->zName
);
860 if( sqlite3_stricmp(p
->zColl
, pCons
->zColl
) ){
861 if( idxIdentifierRequiresQuotes(pCons
->zColl
) ){
862 zRet
= idxAppendText(pRc
, zRet
, " COLLATE %Q", pCons
->zColl
);
864 zRet
= idxAppendText(pRc
, zRet
, " COLLATE %s", pCons
->zColl
);
869 zRet
= idxAppendText(pRc
, zRet
, " DESC");
875 ** Search database dbm for an index compatible with the one idxCreateFromCons()
876 ** would create from arguments pScan, pEq and pTail. If no error occurs and
877 ** such an index is found, return non-zero. Or, if no such index is found,
880 ** If an error occurs, set *pRc to an SQLite error code and return zero.
882 static int idxFindCompatible(
883 int *pRc
, /* OUT: Error code */
884 sqlite3
* dbm
, /* Database to search */
885 IdxScan
*pScan
, /* Scan for table to search for index on */
886 IdxConstraint
*pEq
, /* List of == constraints */
887 IdxConstraint
*pTail
/* List of range constraints */
889 const char *zTbl
= pScan
->pTab
->zName
;
890 sqlite3_stmt
*pIdxList
= 0;
891 IdxConstraint
*pIter
;
892 int nEq
= 0; /* Number of elements in pEq */
895 /* Count the elements in list pEq */
896 for(pIter
=pEq
; pIter
; pIter
=pIter
->pLink
) nEq
++;
898 rc
= idxPrintfPrepareStmt(dbm
, &pIdxList
, 0, "PRAGMA index_list=%Q", zTbl
);
899 while( rc
==SQLITE_OK
&& sqlite3_step(pIdxList
)==SQLITE_ROW
){
901 IdxConstraint
*pT
= pTail
;
902 sqlite3_stmt
*pInfo
= 0;
903 const char *zIdx
= (const char*)sqlite3_column_text(pIdxList
, 1);
904 if( zIdx
==0 ) continue;
906 /* Zero the IdxConstraint.bFlag values in the pEq list */
907 for(pIter
=pEq
; pIter
; pIter
=pIter
->pLink
) pIter
->bFlag
= 0;
909 rc
= idxPrintfPrepareStmt(dbm
, &pInfo
, 0, "PRAGMA index_xInfo=%Q", zIdx
);
910 while( rc
==SQLITE_OK
&& sqlite3_step(pInfo
)==SQLITE_ROW
){
911 int iIdx
= sqlite3_column_int(pInfo
, 0);
912 int iCol
= sqlite3_column_int(pInfo
, 1);
913 const char *zColl
= (const char*)sqlite3_column_text(pInfo
, 4);
916 for(pIter
=pEq
; pIter
; pIter
=pIter
->pLink
){
917 if( pIter
->bFlag
) continue;
918 if( pIter
->iCol
!=iCol
) continue;
919 if( sqlite3_stricmp(pIter
->zColl
, zColl
) ) continue;
929 if( pT
->iCol
!=iCol
|| sqlite3_stricmp(pT
->zColl
, zColl
) ){
937 idxFinalize(&rc
, pInfo
);
939 if( rc
==SQLITE_OK
&& bMatch
){
940 sqlite3_finalize(pIdxList
);
944 idxFinalize(&rc
, pIdxList
);
950 /* Callback for sqlite3_exec() with query with leading count(*) column.
951 * The first argument is expected to be an int*, referent to be incremented
952 * if that leading column is not exactly '0'.
954 static int countNonzeros(void* pCount
, int nc
,
955 char* azResults
[], char* azColumns
[]){
956 (void)azColumns
; /* Suppress unused parameter warning */
957 if( nc
>0 && (azResults
[0][0]!='0' || azResults
[0][1]!=0) ){
958 *((int *)pCount
) += 1;
963 static int idxCreateFromCons(
969 sqlite3
*dbm
= p
->dbm
;
971 if( (pEq
|| pTail
) && 0==idxFindCompatible(&rc
, dbm
, pScan
, pEq
, pTail
) ){
972 IdxTable
*pTab
= pScan
->pTab
;
975 IdxConstraint
*pCons
;
979 for(pCons
=pEq
; pCons
; pCons
=pCons
->pLink
){
980 zCols
= idxAppendColDefn(&rc
, zCols
, pTab
, pCons
);
982 for(pCons
=pTail
; pCons
; pCons
=pCons
->pLink
){
983 zCols
= idxAppendColDefn(&rc
, zCols
, pTab
, pCons
);
987 /* Hash the list of columns to come up with a name for the index */
988 const char *zTable
= pScan
->pTab
->zName
;
989 int quoteTable
= idxIdentifierRequiresQuotes(zTable
);
990 char *zName
= 0; /* Index name */
995 for(i
=0; zCols
[i
]; i
++){
996 h
+= ((h
<<3) + zCols
[i
]);
999 zName
= sqlite3_mprintf("%s_idx_%08x", zTable
, h
);
1000 if( zName
==0 ) break;
1001 /* Is is unique among table, view and index names? */
1002 zFmt
= "SELECT count(*) FROM sqlite_schema WHERE name=%Q"
1003 " AND type in ('index','table','view')";
1004 zFind
= sqlite3_mprintf(zFmt
, zName
);
1006 rc
= sqlite3_exec(dbm
, zFind
, countNonzeros
, &i
, 0);
1007 assert(rc
==SQLITE_OK
);
1008 sqlite3_free(zFind
);
1014 }while( collisions
<50 && zName
!=0 );
1016 /* This return means "Gave up trying to find a unique index name." */
1017 rc
= SQLITE_BUSY_TIMEOUT
;
1018 }else if( zName
==0 ){
1022 zFmt
= "CREATE INDEX \"%w\" ON \"%w\"(%s)";
1024 zFmt
= "CREATE INDEX %s ON %s(%s)";
1026 zIdx
= sqlite3_mprintf(zFmt
, zName
, zTable
, zCols
);
1030 rc
= sqlite3_exec(dbm
, zIdx
, 0, 0, p
->pzErrmsg
);
1031 if( rc
!=SQLITE_OK
){
1032 rc
= SQLITE_BUSY_TIMEOUT
;
1034 idxHashAdd(&rc
, &p
->hIdx
, zName
, zIdx
);
1037 sqlite3_free(zName
);
1042 sqlite3_free(zCols
);
1048 ** Return true if list pList (linked by IdxConstraint.pLink) contains
1049 ** a constraint compatible with *p. Otherwise return false.
1051 static int idxFindConstraint(IdxConstraint
*pList
, IdxConstraint
*p
){
1052 IdxConstraint
*pCmp
;
1053 for(pCmp
=pList
; pCmp
; pCmp
=pCmp
->pLink
){
1054 if( p
->iCol
==pCmp
->iCol
) return 1;
1059 static int idxCreateFromWhere(
1061 IdxScan
*pScan
, /* Create indexes for this scan */
1062 IdxConstraint
*pTail
/* range/ORDER BY constraints for inclusion */
1064 IdxConstraint
*p1
= 0;
1065 IdxConstraint
*pCon
;
1068 /* Gather up all the == constraints. */
1069 for(pCon
=pScan
->pEq
; pCon
; pCon
=pCon
->pNext
){
1070 if( !idxFindConstraint(p1
, pCon
) && !idxFindConstraint(pTail
, pCon
) ){
1076 /* Create an index using the == constraints collected above. And the
1077 ** range constraint/ORDER BY terms passed in by the caller, if any. */
1078 rc
= idxCreateFromCons(p
, pScan
, p1
, pTail
);
1080 /* If no range/ORDER BY passed by the caller, create a version of the
1081 ** index for each range constraint. */
1083 for(pCon
=pScan
->pRange
; rc
==SQLITE_OK
&& pCon
; pCon
=pCon
->pNext
){
1084 assert( pCon
->pLink
==0 );
1085 if( !idxFindConstraint(p1
, pCon
) && !idxFindConstraint(pTail
, pCon
) ){
1086 rc
= idxCreateFromCons(p
, pScan
, p1
, pCon
);
1095 ** Create candidate indexes in database [dbm] based on the data in
1096 ** linked-list pScan.
1098 static int idxCreateCandidates(sqlite3expert
*p
){
1102 for(pIter
=p
->pScan
; pIter
&& rc
==SQLITE_OK
; pIter
=pIter
->pNextScan
){
1103 rc
= idxCreateFromWhere(p
, pIter
, 0);
1104 if( rc
==SQLITE_OK
&& pIter
->pOrder
){
1105 rc
= idxCreateFromWhere(p
, pIter
, pIter
->pOrder
);
1113 ** Free all elements of the linked list starting at pConstraint.
1115 static void idxConstraintFree(IdxConstraint
*pConstraint
){
1116 IdxConstraint
*pNext
;
1119 for(p
=pConstraint
; p
; p
=pNext
){
1126 ** Free all elements of the linked list starting from pScan up until pLast
1127 ** (pLast is not freed).
1129 static void idxScanFree(IdxScan
*pScan
, IdxScan
*pLast
){
1132 for(p
=pScan
; p
!=pLast
; p
=pNext
){
1133 pNext
= p
->pNextScan
;
1134 idxConstraintFree(p
->pOrder
);
1135 idxConstraintFree(p
->pEq
);
1136 idxConstraintFree(p
->pRange
);
1142 ** Free all elements of the linked list starting from pStatement up
1143 ** until pLast (pLast is not freed).
1145 static void idxStatementFree(IdxStatement
*pStatement
, IdxStatement
*pLast
){
1147 IdxStatement
*pNext
;
1148 for(p
=pStatement
; p
!=pLast
; p
=pNext
){
1150 sqlite3_free(p
->zEQP
);
1151 sqlite3_free(p
->zIdx
);
1157 ** Free the linked list of IdxTable objects starting at pTab.
1159 static void idxTableFree(IdxTable
*pTab
){
1162 for(pIter
=pTab
; pIter
; pIter
=pNext
){
1163 pNext
= pIter
->pNext
;
1164 sqlite3_free(pIter
);
1169 ** Free the linked list of IdxWrite objects starting at pTab.
1171 static void idxWriteFree(IdxWrite
*pTab
){
1174 for(pIter
=pTab
; pIter
; pIter
=pNext
){
1175 pNext
= pIter
->pNext
;
1176 sqlite3_free(pIter
);
1183 ** This function is called after candidate indexes have been created. It
1184 ** runs all the queries to see which indexes they prefer, and populates
1185 ** IdxStatement.zIdx and IdxStatement.zEQP with the results.
1187 static int idxFindIndexes(
1189 char **pzErr
/* OUT: Error message (sqlite3_malloc) */
1191 IdxStatement
*pStmt
;
1192 sqlite3
*dbm
= p
->dbm
;
1198 for(pStmt
=p
->pStatement
; rc
==SQLITE_OK
&& pStmt
; pStmt
=pStmt
->pNext
){
1199 IdxHashEntry
*pEntry
;
1200 sqlite3_stmt
*pExplain
= 0;
1201 idxHashClear(&hIdx
);
1202 rc
= idxPrintfPrepareStmt(dbm
, &pExplain
, pzErr
,
1203 "EXPLAIN QUERY PLAN %s", pStmt
->zSql
1205 while( rc
==SQLITE_OK
&& sqlite3_step(pExplain
)==SQLITE_ROW
){
1206 /* int iId = sqlite3_column_int(pExplain, 0); */
1207 /* int iParent = sqlite3_column_int(pExplain, 1); */
1208 /* int iNotUsed = sqlite3_column_int(pExplain, 2); */
1209 const char *zDetail
= (const char*)sqlite3_column_text(pExplain
, 3);
1213 if( !zDetail
) continue;
1214 nDetail
= STRLEN(zDetail
);
1216 for(i
=0; i
<nDetail
; i
++){
1217 const char *zIdx
= 0;
1218 if( i
+13<nDetail
&& memcmp(&zDetail
[i
], " USING INDEX ", 13)==0 ){
1219 zIdx
= &zDetail
[i
+13];
1220 }else if( i
+22<nDetail
1221 && memcmp(&zDetail
[i
], " USING COVERING INDEX ", 22)==0
1223 zIdx
= &zDetail
[i
+22];
1228 while( zIdx
[nIdx
]!='\0' && (zIdx
[nIdx
]!=' ' || zIdx
[nIdx
+1]!='(') ){
1231 zSql
= idxHashSearch(&p
->hIdx
, zIdx
, nIdx
);
1233 idxHashAdd(&rc
, &hIdx
, zSql
, 0);
1234 if( rc
) goto find_indexes_out
;
1240 if( zDetail
[0]!='-' ){
1241 pStmt
->zEQP
= idxAppendText(&rc
, pStmt
->zEQP
, "%s\n", zDetail
);
1245 for(pEntry
=hIdx
.pFirst
; pEntry
; pEntry
=pEntry
->pNext
){
1246 pStmt
->zIdx
= idxAppendText(&rc
, pStmt
->zIdx
, "%s;\n", pEntry
->zKey
);
1249 idxFinalize(&rc
, pExplain
);
1253 idxHashClear(&hIdx
);
1257 static int idxAuthCallback(
1263 const char *zTrigger
1268 if( eOp
==SQLITE_INSERT
|| eOp
==SQLITE_UPDATE
|| eOp
==SQLITE_DELETE
){
1269 if( sqlite3_stricmp(zDb
, "main")==0 ){
1270 sqlite3expert
*p
= (sqlite3expert
*)pCtx
;
1272 for(pTab
=p
->pTable
; pTab
; pTab
=pTab
->pNext
){
1273 if( 0==sqlite3_stricmp(z3
, pTab
->zName
) ) break;
1277 for(pWrite
=p
->pWrite
; pWrite
; pWrite
=pWrite
->pNext
){
1278 if( pWrite
->pTab
==pTab
&& pWrite
->eOp
==eOp
) break;
1281 pWrite
= idxMalloc(&rc
, sizeof(IdxWrite
));
1282 if( rc
==SQLITE_OK
){
1283 pWrite
->pTab
= pTab
;
1285 pWrite
->pNext
= p
->pWrite
;
1295 static int idxProcessOneTrigger(
1300 static const char *zInt
= UNIQUE_TABLE_NAME
;
1301 static const char *zDrop
= "DROP TABLE " UNIQUE_TABLE_NAME
;
1302 IdxTable
*pTab
= pWrite
->pTab
;
1303 const char *zTab
= pTab
->zName
;
1305 "SELECT 'CREATE TEMP' || substr(sql, 7) FROM sqlite_schema "
1306 "WHERE tbl_name = %Q AND type IN ('table', 'trigger') "
1308 sqlite3_stmt
*pSelect
= 0;
1312 /* Create the table and its triggers in the temp schema */
1313 rc
= idxPrintfPrepareStmt(p
->db
, &pSelect
, pzErr
, zSql
, zTab
, zTab
);
1314 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pSelect
) ){
1315 const char *zCreate
= (const char*)sqlite3_column_text(pSelect
, 0);
1316 if( zCreate
==0 ) continue;
1317 rc
= sqlite3_exec(p
->dbv
, zCreate
, 0, 0, pzErr
);
1319 idxFinalize(&rc
, pSelect
);
1321 /* Rename the table in the temp schema to zInt */
1322 if( rc
==SQLITE_OK
){
1323 char *z
= sqlite3_mprintf("ALTER TABLE temp.%Q RENAME TO %Q", zTab
, zInt
);
1327 rc
= sqlite3_exec(p
->dbv
, z
, 0, 0, pzErr
);
1332 switch( pWrite
->eOp
){
1333 case SQLITE_INSERT
: {
1335 zWrite
= idxAppendText(&rc
, zWrite
, "INSERT INTO %Q VALUES(", zInt
);
1336 for(i
=0; i
<pTab
->nCol
; i
++){
1337 zWrite
= idxAppendText(&rc
, zWrite
, "%s?", i
==0 ? "" : ", ");
1339 zWrite
= idxAppendText(&rc
, zWrite
, ")");
1342 case SQLITE_UPDATE
: {
1344 zWrite
= idxAppendText(&rc
, zWrite
, "UPDATE %Q SET ", zInt
);
1345 for(i
=0; i
<pTab
->nCol
; i
++){
1346 zWrite
= idxAppendText(&rc
, zWrite
, "%s%Q=?", i
==0 ? "" : ", ",
1353 assert( pWrite
->eOp
==SQLITE_DELETE
);
1354 if( rc
==SQLITE_OK
){
1355 zWrite
= sqlite3_mprintf("DELETE FROM %Q", zInt
);
1356 if( zWrite
==0 ) rc
= SQLITE_NOMEM
;
1361 if( rc
==SQLITE_OK
){
1362 sqlite3_stmt
*pX
= 0;
1363 rc
= sqlite3_prepare_v2(p
->dbv
, zWrite
, -1, &pX
, 0);
1364 idxFinalize(&rc
, pX
);
1365 if( rc
!=SQLITE_OK
){
1366 idxDatabaseError(p
->dbv
, pzErr
);
1369 sqlite3_free(zWrite
);
1371 if( rc
==SQLITE_OK
){
1372 rc
= sqlite3_exec(p
->dbv
, zDrop
, 0, 0, pzErr
);
1378 static int idxProcessTriggers(sqlite3expert
*p
, char **pzErr
){
1381 IdxWrite
*pFirst
= p
->pWrite
;
1383 while( rc
==SQLITE_OK
&& pFirst
!=pEnd
){
1385 for(pIter
=pFirst
; rc
==SQLITE_OK
&& pIter
!=pEnd
; pIter
=pIter
->pNext
){
1386 rc
= idxProcessOneTrigger(p
, pIter
, pzErr
);
1396 static int idxCreateVtabSchema(sqlite3expert
*p
, char **pzErrmsg
){
1397 int rc
= idxRegisterVtab(p
);
1398 sqlite3_stmt
*pSchema
= 0;
1400 /* For each table in the main db schema:
1402 ** 1) Add an entry to the p->pTable list, and
1403 ** 2) Create the equivalent virtual table in dbv.
1405 rc
= idxPrepareStmt(p
->db
, &pSchema
, pzErrmsg
,
1406 "SELECT type, name, sql, 1 FROM sqlite_schema "
1407 "WHERE type IN ('table','view') AND name NOT LIKE 'sqlite_%%' "
1409 "SELECT type, name, sql, 2 FROM sqlite_schema "
1410 "WHERE type = 'trigger'"
1411 " AND tbl_name IN(SELECT name FROM sqlite_schema WHERE type = 'view') "
1414 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pSchema
) ){
1415 const char *zType
= (const char*)sqlite3_column_text(pSchema
, 0);
1416 const char *zName
= (const char*)sqlite3_column_text(pSchema
, 1);
1417 const char *zSql
= (const char*)sqlite3_column_text(pSchema
, 2);
1419 if( zType
==0 || zName
==0 ) continue;
1420 if( zType
[0]=='v' || zType
[1]=='r' ){
1421 if( zSql
) rc
= sqlite3_exec(p
->dbv
, zSql
, 0, 0, pzErrmsg
);
1424 rc
= idxGetTableInfo(p
->db
, zName
, &pTab
, pzErrmsg
);
1425 if( rc
==SQLITE_OK
){
1429 pTab
->pNext
= p
->pTable
;
1432 /* The statement the vtab will pass to sqlite3_declare_vtab() */
1433 zInner
= idxAppendText(&rc
, 0, "CREATE TABLE x(");
1434 for(i
=0; i
<pTab
->nCol
; i
++){
1435 zInner
= idxAppendText(&rc
, zInner
, "%s%Q COLLATE %s",
1436 (i
==0 ? "" : ", "), pTab
->aCol
[i
].zName
, pTab
->aCol
[i
].zColl
1439 zInner
= idxAppendText(&rc
, zInner
, ")");
1441 /* The CVT statement to create the vtab */
1442 zOuter
= idxAppendText(&rc
, 0,
1443 "CREATE VIRTUAL TABLE %Q USING expert(%Q)", zName
, zInner
1445 if( rc
==SQLITE_OK
){
1446 rc
= sqlite3_exec(p
->dbv
, zOuter
, 0, 0, pzErrmsg
);
1448 sqlite3_free(zInner
);
1449 sqlite3_free(zOuter
);
1453 idxFinalize(&rc
, pSchema
);
1457 struct IdxSampleCtx
{
1459 double target
; /* Target nRet/nRow value */
1460 double nRow
; /* Number of rows seen */
1461 double nRet
; /* Number of rows returned */
1464 static void idxSampleFunc(
1465 sqlite3_context
*pCtx
,
1467 sqlite3_value
**argv
1469 struct IdxSampleCtx
*p
= (struct IdxSampleCtx
*)sqlite3_user_data(pCtx
);
1477 bRet
= (p
->nRet
/ p
->nRow
) <= p
->target
;
1480 sqlite3_randomness(2, (void*)&rnd
);
1481 bRet
= ((int)rnd
% 100) <= p
->iTarget
;
1485 sqlite3_result_int(pCtx
, bRet
);
1487 p
->nRet
+= (double)bRet
;
1493 int eType
; /* SQLITE_NULL, INTEGER, REAL, TEXT, BLOB */
1494 i64 iVal
; /* SQLITE_INTEGER value */
1495 double rVal
; /* SQLITE_FLOAT value */
1496 int nByte
; /* Bytes of space allocated at z */
1497 int n
; /* Size of buffer z */
1498 char *z
; /* SQLITE_TEXT/BLOB value */
1503 ** Implementation of scalar function sqlite_expert_rem().
1505 static void idxRemFunc(
1506 sqlite3_context
*pCtx
,
1508 sqlite3_value
**argv
1510 struct IdxRemCtx
*p
= (struct IdxRemCtx
*)sqlite3_user_data(pCtx
);
1511 struct IdxRemSlot
*pSlot
;
1515 iSlot
= sqlite3_value_int(argv
[0]);
1516 assert( iSlot
<p
->nSlot
);
1517 pSlot
= &p
->aSlot
[iSlot
];
1519 switch( pSlot
->eType
){
1524 case SQLITE_INTEGER
:
1525 sqlite3_result_int64(pCtx
, pSlot
->iVal
);
1529 sqlite3_result_double(pCtx
, pSlot
->rVal
);
1533 sqlite3_result_blob(pCtx
, pSlot
->z
, pSlot
->n
, SQLITE_TRANSIENT
);
1537 sqlite3_result_text(pCtx
, pSlot
->z
, pSlot
->n
, SQLITE_TRANSIENT
);
1541 pSlot
->eType
= sqlite3_value_type(argv
[1]);
1542 switch( pSlot
->eType
){
1547 case SQLITE_INTEGER
:
1548 pSlot
->iVal
= sqlite3_value_int64(argv
[1]);
1552 pSlot
->rVal
= sqlite3_value_double(argv
[1]);
1557 int nByte
= sqlite3_value_bytes(argv
[1]);
1558 const void *pData
= 0;
1559 if( nByte
>pSlot
->nByte
){
1560 char *zNew
= (char*)sqlite3_realloc(pSlot
->z
, nByte
*2);
1562 sqlite3_result_error_nomem(pCtx
);
1565 pSlot
->nByte
= nByte
*2;
1569 if( pSlot
->eType
==SQLITE_BLOB
){
1570 pData
= sqlite3_value_blob(argv
[1]);
1571 if( pData
) memcpy(pSlot
->z
, pData
, nByte
);
1573 pData
= sqlite3_value_text(argv
[1]);
1574 memcpy(pSlot
->z
, pData
, nByte
);
1581 static int idxLargestIndex(sqlite3
*db
, int *pnMax
, char **pzErr
){
1584 "SELECT max(i.seqno) FROM "
1585 " sqlite_schema AS s, "
1586 " pragma_index_list(s.name) AS l, "
1587 " pragma_index_info(l.name) AS i "
1588 "WHERE s.type = 'table'";
1589 sqlite3_stmt
*pMax
= 0;
1592 rc
= idxPrepareStmt(db
, &pMax
, pzErr
, zMax
);
1593 if( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pMax
) ){
1594 *pnMax
= sqlite3_column_int(pMax
, 0) + 1;
1596 idxFinalize(&rc
, pMax
);
1601 static int idxPopulateOneStat1(
1603 sqlite3_stmt
*pIndexXInfo
,
1604 sqlite3_stmt
*pWriteStat
,
1614 sqlite3_stmt
*pQuery
= 0;
1618 assert( p
->iSample
>0 );
1620 /* Formulate the query text */
1621 sqlite3_bind_text(pIndexXInfo
, 1, zIdx
, -1, SQLITE_STATIC
);
1622 while( SQLITE_OK
==rc
&& SQLITE_ROW
==sqlite3_step(pIndexXInfo
) ){
1623 const char *zComma
= zCols
==0 ? "" : ", ";
1624 const char *zName
= (const char*)sqlite3_column_text(pIndexXInfo
, 0);
1625 const char *zColl
= (const char*)sqlite3_column_text(pIndexXInfo
, 1);
1626 zCols
= idxAppendText(&rc
, zCols
,
1627 "%sx.%Q IS sqlite_expert_rem(%d, x.%Q) COLLATE %s",
1628 zComma
, zName
, nCol
, zName
, zColl
1630 zOrder
= idxAppendText(&rc
, zOrder
, "%s%d", zComma
, ++nCol
);
1632 sqlite3_reset(pIndexXInfo
);
1633 if( rc
==SQLITE_OK
){
1634 if( p
->iSample
==100 ){
1635 zQuery
= sqlite3_mprintf(
1636 "SELECT %s FROM %Q x ORDER BY %s", zCols
, zTab
, zOrder
1639 zQuery
= sqlite3_mprintf(
1640 "SELECT %s FROM temp."UNIQUE_TABLE_NAME
" x ORDER BY %s", zCols
, zOrder
1644 sqlite3_free(zCols
);
1645 sqlite3_free(zOrder
);
1647 /* Formulate the query text */
1648 if( rc
==SQLITE_OK
){
1649 sqlite3
*dbrem
= (p
->iSample
==100 ? p
->db
: p
->dbv
);
1650 rc
= idxPrepareStmt(dbrem
, &pQuery
, pzErr
, zQuery
);
1652 sqlite3_free(zQuery
);
1654 if( rc
==SQLITE_OK
){
1655 aStat
= (int*)idxMalloc(&rc
, sizeof(int)*(nCol
+1));
1657 if( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pQuery
) ){
1658 IdxHashEntry
*pEntry
;
1660 for(i
=0; i
<=nCol
; i
++) aStat
[i
] = 1;
1661 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pQuery
) ){
1663 for(i
=0; i
<nCol
; i
++){
1664 if( sqlite3_column_int(pQuery
, i
)==0 ) break;
1666 for(/*no-op*/; i
<nCol
; i
++){
1671 if( rc
==SQLITE_OK
){
1673 zStat
= sqlite3_mprintf("%d", s0
);
1674 if( zStat
==0 ) rc
= SQLITE_NOMEM
;
1675 for(i
=1; rc
==SQLITE_OK
&& i
<=nCol
; i
++){
1676 zStat
= idxAppendText(&rc
, zStat
, " %d", (s0
+aStat
[i
]/2) / aStat
[i
]);
1680 if( rc
==SQLITE_OK
){
1681 sqlite3_bind_text(pWriteStat
, 1, zTab
, -1, SQLITE_STATIC
);
1682 sqlite3_bind_text(pWriteStat
, 2, zIdx
, -1, SQLITE_STATIC
);
1683 sqlite3_bind_text(pWriteStat
, 3, zStat
, -1, SQLITE_STATIC
);
1684 sqlite3_step(pWriteStat
);
1685 rc
= sqlite3_reset(pWriteStat
);
1688 pEntry
= idxHashFind(&p
->hIdx
, zIdx
, STRLEN(zIdx
));
1690 assert( pEntry
->zVal2
==0 );
1691 pEntry
->zVal2
= zStat
;
1693 sqlite3_free(zStat
);
1696 sqlite3_free(aStat
);
1697 idxFinalize(&rc
, pQuery
);
1702 static int idxBuildSampleTable(sqlite3expert
*p
, const char *zTab
){
1706 rc
= sqlite3_exec(p
->dbv
,"DROP TABLE IF EXISTS temp."UNIQUE_TABLE_NAME
,0,0,0);
1707 if( rc
!=SQLITE_OK
) return rc
;
1709 zSql
= sqlite3_mprintf(
1710 "CREATE TABLE temp." UNIQUE_TABLE_NAME
" AS SELECT * FROM %Q", zTab
1712 if( zSql
==0 ) return SQLITE_NOMEM
;
1713 rc
= sqlite3_exec(p
->dbv
, zSql
, 0, 0, 0);
1720 ** This function is called as part of sqlite3_expert_analyze(). Candidate
1721 ** indexes have already been created in database sqlite3expert.dbm, this
1722 ** function populates sqlite_stat1 table in the same database.
1724 ** The stat1 data is generated by querying the
1726 static int idxPopulateStat1(sqlite3expert
*p
, char **pzErr
){
1729 struct IdxRemCtx
*pCtx
= 0;
1730 struct IdxSampleCtx samplectx
;
1732 i64 iPrev
= -100000;
1733 sqlite3_stmt
*pAllIndex
= 0;
1734 sqlite3_stmt
*pIndexXInfo
= 0;
1735 sqlite3_stmt
*pWrite
= 0;
1737 const char *zAllIndex
=
1738 "SELECT s.rowid, s.name, l.name FROM "
1739 " sqlite_schema AS s, "
1740 " pragma_index_list(s.name) AS l "
1741 "WHERE s.type = 'table'";
1742 const char *zIndexXInfo
=
1743 "SELECT name, coll FROM pragma_index_xinfo(?) WHERE key";
1744 const char *zWrite
= "INSERT INTO sqlite_stat1 VALUES(?, ?, ?)";
1746 /* If iSample==0, no sqlite_stat1 data is required. */
1747 if( p
->iSample
==0 ) return SQLITE_OK
;
1749 rc
= idxLargestIndex(p
->dbm
, &nMax
, pzErr
);
1750 if( nMax
<=0 || rc
!=SQLITE_OK
) return rc
;
1752 rc
= sqlite3_exec(p
->dbm
, "ANALYZE; PRAGMA writable_schema=1", 0, 0, 0);
1754 if( rc
==SQLITE_OK
){
1755 int nByte
= sizeof(struct IdxRemCtx
) + (sizeof(struct IdxRemSlot
) * nMax
);
1756 pCtx
= (struct IdxRemCtx
*)idxMalloc(&rc
, nByte
);
1759 if( rc
==SQLITE_OK
){
1760 sqlite3
*dbrem
= (p
->iSample
==100 ? p
->db
: p
->dbv
);
1761 rc
= sqlite3_create_function(dbrem
, "sqlite_expert_rem",
1762 2, SQLITE_UTF8
, (void*)pCtx
, idxRemFunc
, 0, 0
1765 if( rc
==SQLITE_OK
){
1766 rc
= sqlite3_create_function(p
->db
, "sqlite_expert_sample",
1767 0, SQLITE_UTF8
, (void*)&samplectx
, idxSampleFunc
, 0, 0
1771 if( rc
==SQLITE_OK
){
1772 pCtx
->nSlot
= nMax
+1;
1773 rc
= idxPrepareStmt(p
->dbm
, &pAllIndex
, pzErr
, zAllIndex
);
1775 if( rc
==SQLITE_OK
){
1776 rc
= idxPrepareStmt(p
->dbm
, &pIndexXInfo
, pzErr
, zIndexXInfo
);
1778 if( rc
==SQLITE_OK
){
1779 rc
= idxPrepareStmt(p
->dbm
, &pWrite
, pzErr
, zWrite
);
1782 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pAllIndex
) ){
1783 i64 iRowid
= sqlite3_column_int64(pAllIndex
, 0);
1784 const char *zTab
= (const char*)sqlite3_column_text(pAllIndex
, 1);
1785 const char *zIdx
= (const char*)sqlite3_column_text(pAllIndex
, 2);
1786 if( zTab
==0 || zIdx
==0 ) continue;
1787 if( p
->iSample
<100 && iPrev
!=iRowid
){
1788 samplectx
.target
= (double)p
->iSample
/ 100.0;
1789 samplectx
.iTarget
= p
->iSample
;
1790 samplectx
.nRow
= 0.0;
1791 samplectx
.nRet
= 0.0;
1792 rc
= idxBuildSampleTable(p
, zTab
);
1793 if( rc
!=SQLITE_OK
) break;
1795 rc
= idxPopulateOneStat1(p
, pIndexXInfo
, pWrite
, zTab
, zIdx
, pzErr
);
1798 if( rc
==SQLITE_OK
&& p
->iSample
<100 ){
1799 rc
= sqlite3_exec(p
->dbv
,
1800 "DROP TABLE IF EXISTS temp." UNIQUE_TABLE_NAME
, 0,0,0
1804 idxFinalize(&rc
, pAllIndex
);
1805 idxFinalize(&rc
, pIndexXInfo
);
1806 idxFinalize(&rc
, pWrite
);
1809 for(i
=0; i
<pCtx
->nSlot
; i
++){
1810 sqlite3_free(pCtx
->aSlot
[i
].z
);
1815 if( rc
==SQLITE_OK
){
1816 rc
= sqlite3_exec(p
->dbm
, "ANALYZE sqlite_schema", 0, 0, 0);
1819 sqlite3_create_function(p
->db
, "sqlite_expert_rem", 2, SQLITE_UTF8
, 0,0,0,0);
1820 sqlite3_create_function(p
->db
, "sqlite_expert_sample", 0,SQLITE_UTF8
,0,0,0,0);
1822 sqlite3_exec(p
->db
, "DROP TABLE IF EXISTS temp."UNIQUE_TABLE_NAME
,0,0,0);
1827 ** Define and possibly pretend to use a useless collation sequence.
1828 ** This pretense allows expert to accept SQL using custom collations.
1830 int dummyCompare(void *up1
, int up2
, const void *up3
, int up4
, const void *up5
){
1836 assert(0); /* VDBE should never be run. */
1839 /* And a callback to register above upon actual need */
1840 void useDummyCS(void *up1
, sqlite3
*db
, int etr
, const char *zName
){
1842 sqlite3_create_collation_v2(db
, zName
, etr
, 0, dummyCompare
, 0);
1845 #if !defined(SQLITE_OMIT_SCHEMA_PRAGMAS) \
1846 && !defined(SQLITE_OMIT_INTROSPECTION_PRAGMAS)
1848 ** dummy functions for no-op implementation of UDFs during expert's work
1850 void dummyUDF(sqlite3_context
*up1
, int up2
, sqlite3_value
**up3
){
1854 assert(0); /* VDBE should never be run. */
1856 void dummyUDFvalue(sqlite3_context
*up1
){
1858 assert(0); /* VDBE should never be run. */
1862 ** Register UDFs from user database with another.
1864 int registerUDFs(sqlite3
*dbSrc
, sqlite3
*dbDst
){
1865 sqlite3_stmt
*pStmt
;
1866 int rc
= sqlite3_prepare_v2(dbSrc
,
1867 "SELECT name,type,enc,narg,flags "
1868 "FROM pragma_function_list() "
1869 "WHERE builtin==0", -1, &pStmt
, 0);
1870 if( rc
==SQLITE_OK
){
1871 while( SQLITE_ROW
==(rc
= sqlite3_step(pStmt
)) ){
1872 int nargs
= sqlite3_column_int(pStmt
,3);
1873 int flags
= sqlite3_column_int(pStmt
,4);
1874 const char *name
= (char*)sqlite3_column_text(pStmt
,0);
1875 const char *type
= (char*)sqlite3_column_text(pStmt
,1);
1876 const char *enc
= (char*)sqlite3_column_text(pStmt
,2);
1877 if( name
==0 || type
==0 || enc
==0 ){
1878 /* no-op. Only happens on OOM */
1880 int ienc
= SQLITE_UTF8
;
1881 int rcf
= SQLITE_ERROR
;
1882 if( strcmp(enc
,"utf16le")==0 ) ienc
= SQLITE_UTF16LE
;
1883 else if( strcmp(enc
,"utf16be")==0 ) ienc
= SQLITE_UTF16BE
;
1884 ienc
|= (flags
& (SQLITE_DETERMINISTIC
|SQLITE_DIRECTONLY
));
1885 if( strcmp(type
,"w")==0 ){
1886 rcf
= sqlite3_create_window_function(dbDst
,name
,nargs
,ienc
,0,
1887 dummyUDF
,dummyUDFvalue
,0,0,0);
1888 }else if( strcmp(type
,"a")==0 ){
1889 rcf
= sqlite3_create_function(dbDst
,name
,nargs
,ienc
,0,
1890 0,dummyUDF
,dummyUDFvalue
);
1891 }else if( strcmp(type
,"s")==0 ){
1892 rcf
= sqlite3_create_function(dbDst
,name
,nargs
,ienc
,0,
1895 if( rcf
!=SQLITE_OK
){
1901 sqlite3_finalize(pStmt
);
1902 if( rc
==SQLITE_DONE
) rc
= SQLITE_OK
;
1909 ** Allocate a new sqlite3expert object.
1911 sqlite3expert
*sqlite3_expert_new(sqlite3
*db
, char **pzErrmsg
){
1913 sqlite3expert
*pNew
;
1915 pNew
= (sqlite3expert
*)idxMalloc(&rc
, sizeof(sqlite3expert
));
1917 /* Open two in-memory databases to work with. The "vtab database" (dbv)
1918 ** will contain a virtual table corresponding to each real table in
1919 ** the user database schema, and a copy of each view. It is used to
1920 ** collect information regarding the WHERE, ORDER BY and other clauses
1921 ** of the user's query.
1923 if( rc
==SQLITE_OK
){
1925 pNew
->iSample
= 100;
1926 rc
= sqlite3_open(":memory:", &pNew
->dbv
);
1928 if( rc
==SQLITE_OK
){
1929 rc
= sqlite3_open(":memory:", &pNew
->dbm
);
1930 if( rc
==SQLITE_OK
){
1931 sqlite3_db_config(pNew
->dbm
, SQLITE_DBCONFIG_TRIGGER_EQP
, 1, (int*)0);
1935 /* Allow custom collations to be dealt with through prepare. */
1936 if( rc
==SQLITE_OK
) rc
= sqlite3_collation_needed(pNew
->dbm
,0,useDummyCS
);
1937 if( rc
==SQLITE_OK
) rc
= sqlite3_collation_needed(pNew
->dbv
,0,useDummyCS
);
1939 #if !defined(SQLITE_OMIT_SCHEMA_PRAGMAS) \
1940 && !defined(SQLITE_OMIT_INTROSPECTION_PRAGMAS)
1941 /* Register UDFs from database [db] with [dbm] and [dbv]. */
1942 if( rc
==SQLITE_OK
){
1943 rc
= registerUDFs(pNew
->db
, pNew
->dbm
);
1945 if( rc
==SQLITE_OK
){
1946 rc
= registerUDFs(pNew
->db
, pNew
->dbv
);
1950 /* Copy the entire schema of database [db] into [dbm]. */
1951 if( rc
==SQLITE_OK
){
1952 sqlite3_stmt
*pSql
= 0;
1953 rc
= idxPrintfPrepareStmt(pNew
->db
, &pSql
, pzErrmsg
,
1954 "SELECT sql FROM sqlite_schema WHERE name NOT LIKE 'sqlite_%%'"
1955 " AND sql NOT LIKE 'CREATE VIRTUAL %%' ORDER BY rowid"
1957 while( rc
==SQLITE_OK
&& SQLITE_ROW
==sqlite3_step(pSql
) ){
1958 const char *zSql
= (const char*)sqlite3_column_text(pSql
, 0);
1959 if( zSql
) rc
= sqlite3_exec(pNew
->dbm
, zSql
, 0, 0, pzErrmsg
);
1961 idxFinalize(&rc
, pSql
);
1964 /* Create the vtab schema */
1965 if( rc
==SQLITE_OK
){
1966 rc
= idxCreateVtabSchema(pNew
, pzErrmsg
);
1969 /* Register the auth callback with dbv */
1970 if( rc
==SQLITE_OK
){
1971 sqlite3_set_authorizer(pNew
->dbv
, idxAuthCallback
, (void*)pNew
);
1974 /* If an error has occurred, free the new object and reutrn NULL. Otherwise,
1975 ** return the new sqlite3expert handle. */
1976 if( rc
!=SQLITE_OK
){
1977 sqlite3_expert_destroy(pNew
);
1984 ** Configure an sqlite3expert object.
1986 int sqlite3_expert_config(sqlite3expert
*p
, int op
, ...){
1991 case EXPERT_CONFIG_SAMPLE
: {
1992 int iVal
= va_arg(ap
, int);
1993 if( iVal
<0 ) iVal
= 0;
1994 if( iVal
>100 ) iVal
= 100;
1999 rc
= SQLITE_NOTFOUND
;
2008 ** Add an SQL statement to the analysis.
2010 int sqlite3_expert_sql(
2011 sqlite3expert
*p
, /* From sqlite3_expert_new() */
2012 const char *zSql
, /* SQL statement to add */
2013 char **pzErr
/* OUT: Error message (if any) */
2015 IdxScan
*pScanOrig
= p
->pScan
;
2016 IdxStatement
*pStmtOrig
= p
->pStatement
;
2018 const char *zStmt
= zSql
;
2020 if( p
->bRun
) return SQLITE_MISUSE
;
2022 while( rc
==SQLITE_OK
&& zStmt
&& zStmt
[0] ){
2023 sqlite3_stmt
*pStmt
= 0;
2024 /* Ensure that the provided statement compiles against user's DB. */
2025 rc
= idxPrepareStmt(p
->db
, &pStmt
, pzErr
, zStmt
);
2026 if( rc
!=SQLITE_OK
) break;
2027 sqlite3_finalize(pStmt
);
2028 rc
= sqlite3_prepare_v2(p
->dbv
, zStmt
, -1, &pStmt
, &zStmt
);
2029 if( rc
==SQLITE_OK
){
2032 const char *z
= sqlite3_sql(pStmt
);
2034 pNew
= (IdxStatement
*)idxMalloc(&rc
, sizeof(IdxStatement
) + n
+1);
2035 if( rc
==SQLITE_OK
){
2036 pNew
->zSql
= (char*)&pNew
[1];
2037 memcpy(pNew
->zSql
, z
, n
+1);
2038 pNew
->pNext
= p
->pStatement
;
2039 if( p
->pStatement
) pNew
->iId
= p
->pStatement
->iId
+1;
2040 p
->pStatement
= pNew
;
2042 sqlite3_finalize(pStmt
);
2045 idxDatabaseError(p
->dbv
, pzErr
);
2049 if( rc
!=SQLITE_OK
){
2050 idxScanFree(p
->pScan
, pScanOrig
);
2051 idxStatementFree(p
->pStatement
, pStmtOrig
);
2052 p
->pScan
= pScanOrig
;
2053 p
->pStatement
= pStmtOrig
;
2059 int sqlite3_expert_analyze(sqlite3expert
*p
, char **pzErr
){
2061 IdxHashEntry
*pEntry
;
2063 /* Do trigger processing to collect any extra IdxScan structures */
2064 rc
= idxProcessTriggers(p
, pzErr
);
2066 /* Create candidate indexes within the in-memory database file */
2067 if( rc
==SQLITE_OK
){
2068 rc
= idxCreateCandidates(p
);
2069 }else if ( rc
==SQLITE_BUSY_TIMEOUT
){
2071 *pzErr
= sqlite3_mprintf("Cannot find a unique index name to propose.");
2075 /* Generate the stat1 data */
2076 if( rc
==SQLITE_OK
){
2077 rc
= idxPopulateStat1(p
, pzErr
);
2080 /* Formulate the EXPERT_REPORT_CANDIDATES text */
2081 for(pEntry
=p
->hIdx
.pFirst
; pEntry
; pEntry
=pEntry
->pNext
){
2082 p
->zCandidates
= idxAppendText(&rc
, p
->zCandidates
,
2083 "%s;%s%s\n", pEntry
->zVal
,
2084 pEntry
->zVal2
? " -- stat1: " : "", pEntry
->zVal2
2088 /* Figure out which of the candidate indexes are preferred by the query
2089 ** planner and report the results to the user. */
2090 if( rc
==SQLITE_OK
){
2091 rc
= idxFindIndexes(p
, pzErr
);
2094 if( rc
==SQLITE_OK
){
2101 ** Return the total number of statements that have been added to this
2102 ** sqlite3expert using sqlite3_expert_sql().
2104 int sqlite3_expert_count(sqlite3expert
*p
){
2106 if( p
->pStatement
) nRet
= p
->pStatement
->iId
+1;
2111 ** Return a component of the report.
2113 const char *sqlite3_expert_report(sqlite3expert
*p
, int iStmt
, int eReport
){
2114 const char *zRet
= 0;
2115 IdxStatement
*pStmt
;
2117 if( p
->bRun
==0 ) return 0;
2118 for(pStmt
=p
->pStatement
; pStmt
&& pStmt
->iId
!=iStmt
; pStmt
=pStmt
->pNext
);
2120 case EXPERT_REPORT_SQL
:
2121 if( pStmt
) zRet
= pStmt
->zSql
;
2123 case EXPERT_REPORT_INDEXES
:
2124 if( pStmt
) zRet
= pStmt
->zIdx
;
2126 case EXPERT_REPORT_PLAN
:
2127 if( pStmt
) zRet
= pStmt
->zEQP
;
2129 case EXPERT_REPORT_CANDIDATES
:
2130 zRet
= p
->zCandidates
;
2137 ** Free an sqlite3expert object.
2139 void sqlite3_expert_destroy(sqlite3expert
*p
){
2141 sqlite3_close(p
->dbm
);
2142 sqlite3_close(p
->dbv
);
2143 idxScanFree(p
->pScan
, 0);
2144 idxStatementFree(p
->pStatement
, 0);
2145 idxTableFree(p
->pTable
);
2146 idxWriteFree(p
->pWrite
);
2147 idxHashClear(&p
->hIdx
);
2148 sqlite3_free(p
->zCandidates
);
2153 #endif /* ifndef SQLITE_OMIT_VIRTUALTABLE */