1cce7d176Sdrh /* 2b19a2bc6Sdrh ** 2001 September 15 3cce7d176Sdrh ** 4b19a2bc6Sdrh ** The author disclaims copyright to this source code. In place of 5b19a2bc6Sdrh ** a legal notice, here is a blessing: 6cce7d176Sdrh ** 7b19a2bc6Sdrh ** May you do good and not evil. 8b19a2bc6Sdrh ** May you find forgiveness for yourself and forgive others. 9b19a2bc6Sdrh ** May you share freely, never taking more than you give. 10cce7d176Sdrh ** 11cce7d176Sdrh ************************************************************************* 12cce7d176Sdrh ** This file contains C code routines that are called by the parser 13b19a2bc6Sdrh ** to handle SELECT statements in SQLite. 14cce7d176Sdrh */ 15cce7d176Sdrh #include "sqliteInt.h" 16cce7d176Sdrh 17079a3072Sdrh /* 18abd4c723Sdrh ** Trace output macros 19abd4c723Sdrh */ 20abd4c723Sdrh #if SELECTTRACE_ENABLED 21abd4c723Sdrh /***/ int sqlite3SelectTrace = 0; 22eb9b884cSdrh # define SELECTTRACE(K,P,S,X) \ 23eb9b884cSdrh if(sqlite3SelectTrace&(K)) \ 24eb9b884cSdrh sqlite3DebugPrintf("%*s%s.%p: ",(P)->nSelectIndent*2-2,"",(S)->zSelName,(S)),\ 25eb9b884cSdrh sqlite3DebugPrintf X 26abd4c723Sdrh #else 27eb9b884cSdrh # define SELECTTRACE(K,P,S,X) 28abd4c723Sdrh #endif 29abd4c723Sdrh 30abd4c723Sdrh 31abd4c723Sdrh /* 32079a3072Sdrh ** An instance of the following object is used to record information about 33079a3072Sdrh ** how to process the DISTINCT keyword, to simplify passing that information 34079a3072Sdrh ** into the selectInnerLoop() routine. 35079a3072Sdrh */ 36079a3072Sdrh typedef struct DistinctCtx DistinctCtx; 37079a3072Sdrh struct DistinctCtx { 38079a3072Sdrh u8 isTnct; /* True if the DISTINCT keyword is present */ 39079a3072Sdrh u8 eTnctType; /* One of the WHERE_DISTINCT_* operators */ 40079a3072Sdrh int tabTnct; /* Ephemeral table used for DISTINCT processing */ 41079a3072Sdrh int addrTnct; /* Address of OP_OpenEphemeral opcode for tabTnct */ 42079a3072Sdrh }; 43079a3072Sdrh 44079a3072Sdrh /* 45079a3072Sdrh ** An instance of the following object is used to record information about 46079a3072Sdrh ** the ORDER BY (or GROUP BY) clause of query is being coded. 47079a3072Sdrh */ 48079a3072Sdrh typedef struct SortCtx SortCtx; 49079a3072Sdrh struct SortCtx { 50079a3072Sdrh ExprList *pOrderBy; /* The ORDER BY (or GROUP BY clause) */ 51079a3072Sdrh int nOBSat; /* Number of ORDER BY terms satisfied by indices */ 52079a3072Sdrh int iECursor; /* Cursor number for the sorter */ 53079a3072Sdrh int regReturn; /* Register holding block-output return address */ 54079a3072Sdrh int labelBkOut; /* Start label for the block-output subroutine */ 55079a3072Sdrh int addrSortIndex; /* Address of the OP_SorterOpen or OP_OpenEphemeral */ 56079a3072Sdrh u8 sortFlags; /* Zero or more SORTFLAG_* bits */ 57079a3072Sdrh }; 58079a3072Sdrh #define SORTFLAG_UseSorter 0x01 /* Use SorterOpen instead of OpenEphemeral */ 59315555caSdrh 60cce7d176Sdrh /* 61eda639e1Sdrh ** Delete all the content of a Select structure but do not deallocate 62eda639e1Sdrh ** the select structure itself. 63eda639e1Sdrh */ 64633e6d57Sdrh static void clearSelect(sqlite3 *db, Select *p){ 65633e6d57Sdrh sqlite3ExprListDelete(db, p->pEList); 66633e6d57Sdrh sqlite3SrcListDelete(db, p->pSrc); 67633e6d57Sdrh sqlite3ExprDelete(db, p->pWhere); 68633e6d57Sdrh sqlite3ExprListDelete(db, p->pGroupBy); 69633e6d57Sdrh sqlite3ExprDelete(db, p->pHaving); 70633e6d57Sdrh sqlite3ExprListDelete(db, p->pOrderBy); 71633e6d57Sdrh sqlite3SelectDelete(db, p->pPrior); 72633e6d57Sdrh sqlite3ExprDelete(db, p->pLimit); 73633e6d57Sdrh sqlite3ExprDelete(db, p->pOffset); 744e9119d9Sdan sqlite3WithDelete(db, p->pWith); 75eda639e1Sdrh } 76eda639e1Sdrh 771013c932Sdrh /* 781013c932Sdrh ** Initialize a SelectDest structure. 791013c932Sdrh */ 801013c932Sdrh void sqlite3SelectDestInit(SelectDest *pDest, int eDest, int iParm){ 81ea678832Sdrh pDest->eDest = (u8)eDest; 822b596da8Sdrh pDest->iSDParm = iParm; 832b596da8Sdrh pDest->affSdst = 0; 842b596da8Sdrh pDest->iSdst = 0; 852b596da8Sdrh pDest->nSdst = 0; 861013c932Sdrh } 871013c932Sdrh 88eda639e1Sdrh 89eda639e1Sdrh /* 909bb61fe7Sdrh ** Allocate a new Select structure and return a pointer to that 919bb61fe7Sdrh ** structure. 92cce7d176Sdrh */ 934adee20fSdanielk1977 Select *sqlite3SelectNew( 9417435752Sdrh Parse *pParse, /* Parsing context */ 95daffd0e5Sdrh ExprList *pEList, /* which columns to include in the result */ 96ad3cab52Sdrh SrcList *pSrc, /* the FROM clause -- which tables to scan */ 97daffd0e5Sdrh Expr *pWhere, /* the WHERE clause */ 98daffd0e5Sdrh ExprList *pGroupBy, /* the GROUP BY clause */ 99daffd0e5Sdrh Expr *pHaving, /* the HAVING clause */ 100daffd0e5Sdrh ExprList *pOrderBy, /* the ORDER BY clause */ 101832ee3d4Sdrh u16 selFlags, /* Flag parameters, such as SF_Distinct */ 102a2dc3b1aSdanielk1977 Expr *pLimit, /* LIMIT value. NULL means not used */ 103a2dc3b1aSdanielk1977 Expr *pOffset /* OFFSET value. NULL means no offset */ 1049bb61fe7Sdrh ){ 1059bb61fe7Sdrh Select *pNew; 106eda639e1Sdrh Select standin; 10717435752Sdrh sqlite3 *db = pParse->db; 10817435752Sdrh pNew = sqlite3DbMallocZero(db, sizeof(*pNew) ); 109d72a276eSdrh assert( db->mallocFailed || !pOffset || pLimit ); /* OFFSET implies LIMIT */ 110daffd0e5Sdrh if( pNew==0 ){ 111338ec3e1Sdrh assert( db->mallocFailed ); 112eda639e1Sdrh pNew = &standin; 113eda639e1Sdrh memset(pNew, 0, sizeof(*pNew)); 114eda639e1Sdrh } 115b733d037Sdrh if( pEList==0 ){ 116b7916a78Sdrh pEList = sqlite3ExprListAppend(pParse, 0, sqlite3Expr(db,TK_ALL,0)); 117b733d037Sdrh } 1189bb61fe7Sdrh pNew->pEList = pEList; 1197b113babSdrh if( pSrc==0 ) pSrc = sqlite3DbMallocZero(db, sizeof(*pSrc)); 1209bb61fe7Sdrh pNew->pSrc = pSrc; 1219bb61fe7Sdrh pNew->pWhere = pWhere; 1229bb61fe7Sdrh pNew->pGroupBy = pGroupBy; 1239bb61fe7Sdrh pNew->pHaving = pHaving; 1249bb61fe7Sdrh pNew->pOrderBy = pOrderBy; 125832ee3d4Sdrh pNew->selFlags = selFlags; 12682c3d636Sdrh pNew->op = TK_SELECT; 127a2dc3b1aSdanielk1977 pNew->pLimit = pLimit; 128a2dc3b1aSdanielk1977 pNew->pOffset = pOffset; 129373cc2ddSdrh assert( pOffset==0 || pLimit!=0 ); 130b9bb7c18Sdrh pNew->addrOpenEphm[0] = -1; 131b9bb7c18Sdrh pNew->addrOpenEphm[1] = -1; 1320a846f96Sdrh if( db->mallocFailed ) { 133633e6d57Sdrh clearSelect(db, pNew); 1340a846f96Sdrh if( pNew!=&standin ) sqlite3DbFree(db, pNew); 135eda639e1Sdrh pNew = 0; 136a464c234Sdrh }else{ 137a464c234Sdrh assert( pNew->pSrc!=0 || pParse->nErr>0 ); 138daffd0e5Sdrh } 139338ec3e1Sdrh assert( pNew!=&standin ); 1409bb61fe7Sdrh return pNew; 1419bb61fe7Sdrh } 1429bb61fe7Sdrh 143eb9b884cSdrh #if SELECTTRACE_ENABLED 144eb9b884cSdrh /* 145eb9b884cSdrh ** Set the name of a Select object 146eb9b884cSdrh */ 147eb9b884cSdrh void sqlite3SelectSetName(Select *p, const char *zName){ 148eb9b884cSdrh if( p && zName ){ 149eb9b884cSdrh sqlite3_snprintf(sizeof(p->zSelName), p->zSelName, "%s", zName); 150eb9b884cSdrh } 151eb9b884cSdrh } 152eb9b884cSdrh #endif 153eb9b884cSdrh 154eb9b884cSdrh 1559bb61fe7Sdrh /* 156eda639e1Sdrh ** Delete the given Select structure and all of its substructures. 157eda639e1Sdrh */ 158633e6d57Sdrh void sqlite3SelectDelete(sqlite3 *db, Select *p){ 159eda639e1Sdrh if( p ){ 160633e6d57Sdrh clearSelect(db, p); 161633e6d57Sdrh sqlite3DbFree(db, p); 162eda639e1Sdrh } 163eda639e1Sdrh } 164eda639e1Sdrh 165eda639e1Sdrh /* 166d227a291Sdrh ** Return a pointer to the right-most SELECT statement in a compound. 167d227a291Sdrh */ 168d227a291Sdrh static Select *findRightmost(Select *p){ 169d227a291Sdrh while( p->pNext ) p = p->pNext; 170d227a291Sdrh return p; 171d227a291Sdrh } 172d227a291Sdrh 173d227a291Sdrh /* 174f7b5496eSdrh ** Given 1 to 3 identifiers preceding the JOIN keyword, determine the 17501f3f253Sdrh ** type of join. Return an integer constant that expresses that type 17601f3f253Sdrh ** in terms of the following bit values: 17701f3f253Sdrh ** 17801f3f253Sdrh ** JT_INNER 1793dec223cSdrh ** JT_CROSS 18001f3f253Sdrh ** JT_OUTER 18101f3f253Sdrh ** JT_NATURAL 18201f3f253Sdrh ** JT_LEFT 18301f3f253Sdrh ** JT_RIGHT 18401f3f253Sdrh ** 18501f3f253Sdrh ** A full outer join is the combination of JT_LEFT and JT_RIGHT. 18601f3f253Sdrh ** 18701f3f253Sdrh ** If an illegal or unsupported join type is seen, then still return 18801f3f253Sdrh ** a join type, but put an error in the pParse structure. 18901f3f253Sdrh */ 1904adee20fSdanielk1977 int sqlite3JoinType(Parse *pParse, Token *pA, Token *pB, Token *pC){ 19101f3f253Sdrh int jointype = 0; 19201f3f253Sdrh Token *apAll[3]; 19301f3f253Sdrh Token *p; 194373cc2ddSdrh /* 0123456789 123456789 123456789 123 */ 195373cc2ddSdrh static const char zKeyText[] = "naturaleftouterightfullinnercross"; 1965719628aSdrh static const struct { 197373cc2ddSdrh u8 i; /* Beginning of keyword text in zKeyText[] */ 198373cc2ddSdrh u8 nChar; /* Length of the keyword in characters */ 199373cc2ddSdrh u8 code; /* Join type mask */ 200373cc2ddSdrh } aKeyword[] = { 201373cc2ddSdrh /* natural */ { 0, 7, JT_NATURAL }, 202373cc2ddSdrh /* left */ { 6, 4, JT_LEFT|JT_OUTER }, 203373cc2ddSdrh /* outer */ { 10, 5, JT_OUTER }, 204373cc2ddSdrh /* right */ { 14, 5, JT_RIGHT|JT_OUTER }, 205373cc2ddSdrh /* full */ { 19, 4, JT_LEFT|JT_RIGHT|JT_OUTER }, 206373cc2ddSdrh /* inner */ { 23, 5, JT_INNER }, 207373cc2ddSdrh /* cross */ { 28, 5, JT_INNER|JT_CROSS }, 20801f3f253Sdrh }; 20901f3f253Sdrh int i, j; 21001f3f253Sdrh apAll[0] = pA; 21101f3f253Sdrh apAll[1] = pB; 21201f3f253Sdrh apAll[2] = pC; 213195e6967Sdrh for(i=0; i<3 && apAll[i]; i++){ 21401f3f253Sdrh p = apAll[i]; 215373cc2ddSdrh for(j=0; j<ArraySize(aKeyword); j++){ 216373cc2ddSdrh if( p->n==aKeyword[j].nChar 217373cc2ddSdrh && sqlite3StrNICmp((char*)p->z, &zKeyText[aKeyword[j].i], p->n)==0 ){ 218373cc2ddSdrh jointype |= aKeyword[j].code; 21901f3f253Sdrh break; 22001f3f253Sdrh } 22101f3f253Sdrh } 222373cc2ddSdrh testcase( j==0 || j==1 || j==2 || j==3 || j==4 || j==5 || j==6 ); 223373cc2ddSdrh if( j>=ArraySize(aKeyword) ){ 22401f3f253Sdrh jointype |= JT_ERROR; 22501f3f253Sdrh break; 22601f3f253Sdrh } 22701f3f253Sdrh } 228ad2d8307Sdrh if( 229ad2d8307Sdrh (jointype & (JT_INNER|JT_OUTER))==(JT_INNER|JT_OUTER) || 230195e6967Sdrh (jointype & JT_ERROR)!=0 231ad2d8307Sdrh ){ 232a9671a22Sdrh const char *zSp = " "; 233a9671a22Sdrh assert( pB!=0 ); 234a9671a22Sdrh if( pC==0 ){ zSp++; } 235ae29ffbeSdrh sqlite3ErrorMsg(pParse, "unknown or unsupported join type: " 236a9671a22Sdrh "%T %T%s%T", pA, pB, zSp, pC); 23701f3f253Sdrh jointype = JT_INNER; 238373cc2ddSdrh }else if( (jointype & JT_OUTER)!=0 239373cc2ddSdrh && (jointype & (JT_LEFT|JT_RIGHT))!=JT_LEFT ){ 2404adee20fSdanielk1977 sqlite3ErrorMsg(pParse, 241da93d238Sdrh "RIGHT and FULL OUTER JOINs are not currently supported"); 242195e6967Sdrh jointype = JT_INNER; 24301f3f253Sdrh } 24401f3f253Sdrh return jointype; 24501f3f253Sdrh } 24601f3f253Sdrh 24701f3f253Sdrh /* 248ad2d8307Sdrh ** Return the index of a column in a table. Return -1 if the column 249ad2d8307Sdrh ** is not contained in the table. 250ad2d8307Sdrh */ 251ad2d8307Sdrh static int columnIndex(Table *pTab, const char *zCol){ 252ad2d8307Sdrh int i; 253ad2d8307Sdrh for(i=0; i<pTab->nCol; i++){ 2544adee20fSdanielk1977 if( sqlite3StrICmp(pTab->aCol[i].zName, zCol)==0 ) return i; 255ad2d8307Sdrh } 256ad2d8307Sdrh return -1; 257ad2d8307Sdrh } 258ad2d8307Sdrh 259ad2d8307Sdrh /* 2602179b434Sdrh ** Search the first N tables in pSrc, from left to right, looking for a 2612179b434Sdrh ** table that has a column named zCol. 2622179b434Sdrh ** 2632179b434Sdrh ** When found, set *piTab and *piCol to the table index and column index 2642179b434Sdrh ** of the matching column and return TRUE. 2652179b434Sdrh ** 2662179b434Sdrh ** If not found, return FALSE. 2672179b434Sdrh */ 2682179b434Sdrh static int tableAndColumnIndex( 2692179b434Sdrh SrcList *pSrc, /* Array of tables to search */ 2702179b434Sdrh int N, /* Number of tables in pSrc->a[] to search */ 2712179b434Sdrh const char *zCol, /* Name of the column we are looking for */ 2722179b434Sdrh int *piTab, /* Write index of pSrc->a[] here */ 2732179b434Sdrh int *piCol /* Write index of pSrc->a[*piTab].pTab->aCol[] here */ 2742179b434Sdrh ){ 2752179b434Sdrh int i; /* For looping over tables in pSrc */ 2762179b434Sdrh int iCol; /* Index of column matching zCol */ 2772179b434Sdrh 2782179b434Sdrh assert( (piTab==0)==(piCol==0) ); /* Both or neither are NULL */ 2792179b434Sdrh for(i=0; i<N; i++){ 2802179b434Sdrh iCol = columnIndex(pSrc->a[i].pTab, zCol); 2812179b434Sdrh if( iCol>=0 ){ 2822179b434Sdrh if( piTab ){ 2832179b434Sdrh *piTab = i; 2842179b434Sdrh *piCol = iCol; 2852179b434Sdrh } 2862179b434Sdrh return 1; 2872179b434Sdrh } 2882179b434Sdrh } 2892179b434Sdrh return 0; 2902179b434Sdrh } 2912179b434Sdrh 2922179b434Sdrh /* 293f7b0b0adSdan ** This function is used to add terms implied by JOIN syntax to the 294f7b0b0adSdan ** WHERE clause expression of a SELECT statement. The new term, which 295f7b0b0adSdan ** is ANDed with the existing WHERE clause, is of the form: 296f7b0b0adSdan ** 297f7b0b0adSdan ** (tab1.col1 = tab2.col2) 298f7b0b0adSdan ** 299f7b0b0adSdan ** where tab1 is the iSrc'th table in SrcList pSrc and tab2 is the 300f7b0b0adSdan ** (iSrc+1)'th. Column col1 is column iColLeft of tab1, and col2 is 301f7b0b0adSdan ** column iColRight of tab2. 302ad2d8307Sdrh */ 303ad2d8307Sdrh static void addWhereTerm( 30417435752Sdrh Parse *pParse, /* Parsing context */ 305f7b0b0adSdan SrcList *pSrc, /* List of tables in FROM clause */ 3062179b434Sdrh int iLeft, /* Index of first table to join in pSrc */ 307f7b0b0adSdan int iColLeft, /* Index of column in first table */ 3082179b434Sdrh int iRight, /* Index of second table in pSrc */ 309f7b0b0adSdan int iColRight, /* Index of column in second table */ 310f7b0b0adSdan int isOuterJoin, /* True if this is an OUTER join */ 311f7b0b0adSdan Expr **ppWhere /* IN/OUT: The WHERE clause to add to */ 312ad2d8307Sdrh ){ 313f7b0b0adSdan sqlite3 *db = pParse->db; 314f7b0b0adSdan Expr *pE1; 315f7b0b0adSdan Expr *pE2; 316f7b0b0adSdan Expr *pEq; 317ad2d8307Sdrh 3182179b434Sdrh assert( iLeft<iRight ); 3192179b434Sdrh assert( pSrc->nSrc>iRight ); 3202179b434Sdrh assert( pSrc->a[iLeft].pTab ); 3212179b434Sdrh assert( pSrc->a[iRight].pTab ); 322f7b0b0adSdan 3232179b434Sdrh pE1 = sqlite3CreateColumnExpr(db, pSrc, iLeft, iColLeft); 3242179b434Sdrh pE2 = sqlite3CreateColumnExpr(db, pSrc, iRight, iColRight); 325f7b0b0adSdan 326f7b0b0adSdan pEq = sqlite3PExpr(pParse, TK_EQ, pE1, pE2, 0); 327f7b0b0adSdan if( pEq && isOuterJoin ){ 328f7b0b0adSdan ExprSetProperty(pEq, EP_FromJoin); 329c5cd1249Sdrh assert( !ExprHasProperty(pEq, EP_TokenOnly|EP_Reduced) ); 330ebb6a65dSdrh ExprSetVVAProperty(pEq, EP_NoReduce); 331f7b0b0adSdan pEq->iRightJoinTable = (i16)pE2->iTable; 332030530deSdrh } 333f7b0b0adSdan *ppWhere = sqlite3ExprAnd(db, *ppWhere, pEq); 334ad2d8307Sdrh } 335ad2d8307Sdrh 336ad2d8307Sdrh /* 3371f16230bSdrh ** Set the EP_FromJoin property on all terms of the given expression. 33822d6a53aSdrh ** And set the Expr.iRightJoinTable to iTable for every term in the 33922d6a53aSdrh ** expression. 3401cc093c2Sdrh ** 341e78e8284Sdrh ** The EP_FromJoin property is used on terms of an expression to tell 3421cc093c2Sdrh ** the LEFT OUTER JOIN processing logic that this term is part of the 3431f16230bSdrh ** join restriction specified in the ON or USING clause and not a part 3441f16230bSdrh ** of the more general WHERE clause. These terms are moved over to the 3451f16230bSdrh ** WHERE clause during join processing but we need to remember that they 3461f16230bSdrh ** originated in the ON or USING clause. 34722d6a53aSdrh ** 34822d6a53aSdrh ** The Expr.iRightJoinTable tells the WHERE clause processing that the 34922d6a53aSdrh ** expression depends on table iRightJoinTable even if that table is not 35022d6a53aSdrh ** explicitly mentioned in the expression. That information is needed 35122d6a53aSdrh ** for cases like this: 35222d6a53aSdrh ** 35322d6a53aSdrh ** SELECT * FROM t1 LEFT JOIN t2 ON t1.a=t2.b AND t1.x=5 35422d6a53aSdrh ** 35522d6a53aSdrh ** The where clause needs to defer the handling of the t1.x=5 35622d6a53aSdrh ** term until after the t2 loop of the join. In that way, a 35722d6a53aSdrh ** NULL t2 row will be inserted whenever t1.x!=5. If we do not 35822d6a53aSdrh ** defer the handling of t1.x=5, it will be processed immediately 35922d6a53aSdrh ** after the t1 loop and rows with t1.x!=5 will never appear in 36022d6a53aSdrh ** the output, which is incorrect. 3611cc093c2Sdrh */ 36222d6a53aSdrh static void setJoinExpr(Expr *p, int iTable){ 3631cc093c2Sdrh while( p ){ 3641f16230bSdrh ExprSetProperty(p, EP_FromJoin); 365c5cd1249Sdrh assert( !ExprHasProperty(p, EP_TokenOnly|EP_Reduced) ); 366ebb6a65dSdrh ExprSetVVAProperty(p, EP_NoReduce); 367cf697396Sshane p->iRightJoinTable = (i16)iTable; 36822d6a53aSdrh setJoinExpr(p->pLeft, iTable); 3691cc093c2Sdrh p = p->pRight; 3701cc093c2Sdrh } 3711cc093c2Sdrh } 3721cc093c2Sdrh 3731cc093c2Sdrh /* 374ad2d8307Sdrh ** This routine processes the join information for a SELECT statement. 375ad2d8307Sdrh ** ON and USING clauses are converted into extra terms of the WHERE clause. 376ad2d8307Sdrh ** NATURAL joins also create extra WHERE clause terms. 377ad2d8307Sdrh ** 37891bb0eedSdrh ** The terms of a FROM clause are contained in the Select.pSrc structure. 37991bb0eedSdrh ** The left most table is the first entry in Select.pSrc. The right-most 38091bb0eedSdrh ** table is the last entry. The join operator is held in the entry to 38191bb0eedSdrh ** the left. Thus entry 0 contains the join operator for the join between 38291bb0eedSdrh ** entries 0 and 1. Any ON or USING clauses associated with the join are 38391bb0eedSdrh ** also attached to the left entry. 38491bb0eedSdrh ** 385ad2d8307Sdrh ** This routine returns the number of errors encountered. 386ad2d8307Sdrh */ 387ad2d8307Sdrh static int sqliteProcessJoin(Parse *pParse, Select *p){ 38891bb0eedSdrh SrcList *pSrc; /* All tables in the FROM clause */ 38991bb0eedSdrh int i, j; /* Loop counters */ 39091bb0eedSdrh struct SrcList_item *pLeft; /* Left table being joined */ 39191bb0eedSdrh struct SrcList_item *pRight; /* Right table being joined */ 392ad2d8307Sdrh 39391bb0eedSdrh pSrc = p->pSrc; 39491bb0eedSdrh pLeft = &pSrc->a[0]; 39591bb0eedSdrh pRight = &pLeft[1]; 39691bb0eedSdrh for(i=0; i<pSrc->nSrc-1; i++, pRight++, pLeft++){ 39791bb0eedSdrh Table *pLeftTab = pLeft->pTab; 39891bb0eedSdrh Table *pRightTab = pRight->pTab; 399ad27e761Sdrh int isOuter; 40091bb0eedSdrh 4011c767f0dSdrh if( NEVER(pLeftTab==0 || pRightTab==0) ) continue; 402ad27e761Sdrh isOuter = (pRight->jointype & JT_OUTER)!=0; 403ad2d8307Sdrh 404ad2d8307Sdrh /* When the NATURAL keyword is present, add WHERE clause terms for 405ad2d8307Sdrh ** every column that the two tables have in common. 406ad2d8307Sdrh */ 40761dfc31dSdrh if( pRight->jointype & JT_NATURAL ){ 40861dfc31dSdrh if( pRight->pOn || pRight->pUsing ){ 4094adee20fSdanielk1977 sqlite3ErrorMsg(pParse, "a NATURAL join may not have " 410ad2d8307Sdrh "an ON or USING clause", 0); 411ad2d8307Sdrh return 1; 412ad2d8307Sdrh } 4132179b434Sdrh for(j=0; j<pRightTab->nCol; j++){ 4142179b434Sdrh char *zName; /* Name of column in the right table */ 4152179b434Sdrh int iLeft; /* Matching left table */ 4162179b434Sdrh int iLeftCol; /* Matching column in the left table */ 4172179b434Sdrh 4182179b434Sdrh zName = pRightTab->aCol[j].zName; 4192179b434Sdrh if( tableAndColumnIndex(pSrc, i+1, zName, &iLeft, &iLeftCol) ){ 4202179b434Sdrh addWhereTerm(pParse, pSrc, iLeft, iLeftCol, i+1, j, 4212179b434Sdrh isOuter, &p->pWhere); 422ad2d8307Sdrh } 423ad2d8307Sdrh } 424ad2d8307Sdrh } 425ad2d8307Sdrh 426ad2d8307Sdrh /* Disallow both ON and USING clauses in the same join 427ad2d8307Sdrh */ 42861dfc31dSdrh if( pRight->pOn && pRight->pUsing ){ 4294adee20fSdanielk1977 sqlite3ErrorMsg(pParse, "cannot have both ON and USING " 430da93d238Sdrh "clauses in the same join"); 431ad2d8307Sdrh return 1; 432ad2d8307Sdrh } 433ad2d8307Sdrh 434ad2d8307Sdrh /* Add the ON clause to the end of the WHERE clause, connected by 43591bb0eedSdrh ** an AND operator. 436ad2d8307Sdrh */ 43761dfc31dSdrh if( pRight->pOn ){ 438ad27e761Sdrh if( isOuter ) setJoinExpr(pRight->pOn, pRight->iCursor); 43917435752Sdrh p->pWhere = sqlite3ExprAnd(pParse->db, p->pWhere, pRight->pOn); 44061dfc31dSdrh pRight->pOn = 0; 441ad2d8307Sdrh } 442ad2d8307Sdrh 443ad2d8307Sdrh /* Create extra terms on the WHERE clause for each column named 444ad2d8307Sdrh ** in the USING clause. Example: If the two tables to be joined are 445ad2d8307Sdrh ** A and B and the USING clause names X, Y, and Z, then add this 446ad2d8307Sdrh ** to the WHERE clause: A.X=B.X AND A.Y=B.Y AND A.Z=B.Z 447ad2d8307Sdrh ** Report an error if any column mentioned in the USING clause is 448ad2d8307Sdrh ** not contained in both tables to be joined. 449ad2d8307Sdrh */ 45061dfc31dSdrh if( pRight->pUsing ){ 45161dfc31dSdrh IdList *pList = pRight->pUsing; 452ad2d8307Sdrh for(j=0; j<pList->nId; j++){ 4532179b434Sdrh char *zName; /* Name of the term in the USING clause */ 4542179b434Sdrh int iLeft; /* Table on the left with matching column name */ 4552179b434Sdrh int iLeftCol; /* Column number of matching column on the left */ 4562179b434Sdrh int iRightCol; /* Column number of matching column on the right */ 4572179b434Sdrh 4582179b434Sdrh zName = pList->a[j].zName; 4592179b434Sdrh iRightCol = columnIndex(pRightTab, zName); 4602179b434Sdrh if( iRightCol<0 4612179b434Sdrh || !tableAndColumnIndex(pSrc, i+1, zName, &iLeft, &iLeftCol) 4622179b434Sdrh ){ 4634adee20fSdanielk1977 sqlite3ErrorMsg(pParse, "cannot join using column %s - column " 46491bb0eedSdrh "not present in both tables", zName); 465ad2d8307Sdrh return 1; 466ad2d8307Sdrh } 4672179b434Sdrh addWhereTerm(pParse, pSrc, iLeft, iLeftCol, i+1, iRightCol, 4682179b434Sdrh isOuter, &p->pWhere); 469ad2d8307Sdrh } 470ad2d8307Sdrh } 471ad2d8307Sdrh } 472ad2d8307Sdrh return 0; 473ad2d8307Sdrh } 474ad2d8307Sdrh 475079a3072Sdrh /* Forward reference */ 476079a3072Sdrh static KeyInfo *keyInfoFromExprList( 477079a3072Sdrh Parse *pParse, /* Parsing context */ 478079a3072Sdrh ExprList *pList, /* Form the KeyInfo object from this ExprList */ 479079a3072Sdrh int iStart, /* Begin with this column of pList */ 480079a3072Sdrh int nExtra /* Add this many extra columns to the end */ 481079a3072Sdrh ); 482079a3072Sdrh 483ad2d8307Sdrh /* 484f45f2326Sdrh ** Generate code that will push the record in registers regData 485f45f2326Sdrh ** through regData+nData-1 onto the sorter. 486c926afbcSdrh */ 487d59ba6ceSdrh static void pushOntoSorter( 488d59ba6ceSdrh Parse *pParse, /* Parser context */ 489079a3072Sdrh SortCtx *pSort, /* Information about the ORDER BY clause */ 490b7654111Sdrh Select *pSelect, /* The whole SELECT statement */ 491f45f2326Sdrh int regData, /* First register holding data to be sorted */ 492fd0a2f97Sdrh int nData, /* Number of elements in the data array */ 493fd0a2f97Sdrh int nPrefixReg /* No. of reg prior to regData available for use */ 494d59ba6ceSdrh ){ 495f45f2326Sdrh Vdbe *v = pParse->pVdbe; /* Stmt under construction */ 49678d58432Sdan int bSeq = ((pSort->sortFlags & SORTFLAG_UseSorter)==0); 497f45f2326Sdrh int nExpr = pSort->pOrderBy->nExpr; /* No. of ORDER BY terms */ 49878d58432Sdan int nBase = nExpr + bSeq + nData; /* Fields in sorter record */ 499fd0a2f97Sdrh int regBase; /* Regs for sorter record */ 500fb0d6e56Sdrh int regRecord = ++pParse->nMem; /* Assembled sorter record */ 50178d58432Sdan int nOBSat = pSort->nOBSat; /* ORDER BY terms to skip */ 502f45f2326Sdrh int op; /* Opcode to add sorter record to sorter */ 503f45f2326Sdrh 50478d58432Sdan assert( bSeq==0 || bSeq==1 ); 505fd0a2f97Sdrh if( nPrefixReg ){ 50678d58432Sdan assert( nPrefixReg==nExpr+bSeq ); 50778d58432Sdan regBase = regData - nExpr - bSeq; 508fd0a2f97Sdrh }else{ 509fb0d6e56Sdrh regBase = pParse->nMem + 1; 510fb0d6e56Sdrh pParse->nMem += nBase; 511fd0a2f97Sdrh } 51270f624c3Sdrh sqlite3ExprCodeExprList(pParse, pSort->pOrderBy, regBase, SQLITE_ECEL_DUP); 51378d58432Sdan if( bSeq ){ 514079a3072Sdrh sqlite3VdbeAddOp2(v, OP_Sequence, pSort->iECursor, regBase+nExpr); 515fd0a2f97Sdrh } 51678d58432Sdan if( nPrefixReg==0 ){ 517236241aeSdrh sqlite3ExprCodeMove(pParse, regData, regBase+nExpr+bSeq, nData); 51878d58432Sdan } 51978d58432Sdan 520f45f2326Sdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, regBase+nOBSat, nBase-nOBSat, regRecord); 521079a3072Sdrh if( nOBSat>0 ){ 522079a3072Sdrh int regPrevKey; /* The first nOBSat columns of the previous row */ 523079a3072Sdrh int addrFirst; /* Address of the OP_IfNot opcode */ 524079a3072Sdrh int addrJmp; /* Address of the OP_Jump opcode */ 525079a3072Sdrh VdbeOp *pOp; /* Opcode that opens the sorter */ 526079a3072Sdrh int nKey; /* Number of sorting key columns, including OP_Sequence */ 527dbfca2b7Sdrh KeyInfo *pKI; /* Original KeyInfo on the sorter table */ 528079a3072Sdrh 52926d7e7c6Sdrh regPrevKey = pParse->nMem+1; 53026d7e7c6Sdrh pParse->nMem += pSort->nOBSat; 53178d58432Sdan nKey = nExpr - pSort->nOBSat + bSeq; 53278d58432Sdan if( bSeq ){ 53378d58432Sdan addrFirst = sqlite3VdbeAddOp1(v, OP_IfNot, regBase+nExpr); 53478d58432Sdan }else{ 53578d58432Sdan addrFirst = sqlite3VdbeAddOp1(v, OP_SequenceTest, pSort->iECursor); 53678d58432Sdan } 53778d58432Sdan VdbeCoverage(v); 53826d7e7c6Sdrh sqlite3VdbeAddOp3(v, OP_Compare, regPrevKey, regBase, pSort->nOBSat); 539079a3072Sdrh pOp = sqlite3VdbeGetOp(v, pSort->addrSortIndex); 54059b8f2e1Sdrh if( pParse->db->mallocFailed ) return; 541fb0d6e56Sdrh pOp->p2 = nKey + nData; 542dbfca2b7Sdrh pKI = pOp->p4.pKeyInfo; 543dbfca2b7Sdrh memset(pKI->aSortOrder, 0, pKI->nField); /* Makes OP_Jump below testable */ 544dbfca2b7Sdrh sqlite3VdbeChangeP4(v, -1, (char*)pKI, P4_KEYINFO); 545079a3072Sdrh pOp->p4.pKeyInfo = keyInfoFromExprList(pParse, pSort->pOrderBy, nOBSat, 1); 546079a3072Sdrh addrJmp = sqlite3VdbeCurrentAddr(v); 547079a3072Sdrh sqlite3VdbeAddOp3(v, OP_Jump, addrJmp+1, 0, addrJmp+1); VdbeCoverage(v); 548079a3072Sdrh pSort->labelBkOut = sqlite3VdbeMakeLabel(v); 549079a3072Sdrh pSort->regReturn = ++pParse->nMem; 550079a3072Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, pSort->regReturn, pSort->labelBkOut); 55165ea12cbSdrh sqlite3VdbeAddOp1(v, OP_ResetSorter, pSort->iECursor); 552079a3072Sdrh sqlite3VdbeJumpHere(v, addrFirst); 553236241aeSdrh sqlite3ExprCodeMove(pParse, regBase, regPrevKey, pSort->nOBSat); 554079a3072Sdrh sqlite3VdbeJumpHere(v, addrJmp); 555079a3072Sdrh } 556079a3072Sdrh if( pSort->sortFlags & SORTFLAG_UseSorter ){ 557c6aff30cSdrh op = OP_SorterInsert; 558c6aff30cSdrh }else{ 559c6aff30cSdrh op = OP_IdxInsert; 560c6aff30cSdrh } 561079a3072Sdrh sqlite3VdbeAddOp2(v, op, pSort->iECursor, regRecord); 56292b01d53Sdrh if( pSelect->iLimit ){ 56315007a99Sdrh int addr1, addr2; 564b7654111Sdrh int iLimit; 5650acb7e48Sdrh if( pSelect->iOffset ){ 566b7654111Sdrh iLimit = pSelect->iOffset+1; 567b7654111Sdrh }else{ 568b7654111Sdrh iLimit = pSelect->iLimit; 569b7654111Sdrh } 570688852abSdrh addr1 = sqlite3VdbeAddOp1(v, OP_IfZero, iLimit); VdbeCoverage(v); 571b7654111Sdrh sqlite3VdbeAddOp2(v, OP_AddImm, iLimit, -1); 5723c84ddffSdrh addr2 = sqlite3VdbeAddOp0(v, OP_Goto); 573d59ba6ceSdrh sqlite3VdbeJumpHere(v, addr1); 574079a3072Sdrh sqlite3VdbeAddOp1(v, OP_Last, pSort->iECursor); 575079a3072Sdrh sqlite3VdbeAddOp1(v, OP_Delete, pSort->iECursor); 57615007a99Sdrh sqlite3VdbeJumpHere(v, addr2); 577d59ba6ceSdrh } 578c926afbcSdrh } 579c926afbcSdrh 580c926afbcSdrh /* 581ec7429aeSdrh ** Add code to implement the OFFSET 582ea48eb2eSdrh */ 583ec7429aeSdrh static void codeOffset( 584bab39e13Sdrh Vdbe *v, /* Generate code into this VM */ 585aa9ce707Sdrh int iOffset, /* Register holding the offset counter */ 586b7654111Sdrh int iContinue /* Jump here to skip the current record */ 587ea48eb2eSdrh ){ 588a22a75e5Sdrh if( iOffset>0 ){ 58915007a99Sdrh int addr; 5904336b0e6Sdrh addr = sqlite3VdbeAddOp3(v, OP_IfNeg, iOffset, 0, -1); VdbeCoverage(v); 59166a5167bSdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, iContinue); 592d4e70ebdSdrh VdbeComment((v, "skip OFFSET records")); 59315007a99Sdrh sqlite3VdbeJumpHere(v, addr); 594ea48eb2eSdrh } 595ea48eb2eSdrh } 596ea48eb2eSdrh 597ea48eb2eSdrh /* 59898757157Sdrh ** Add code that will check to make sure the N registers starting at iMem 59998757157Sdrh ** form a distinct entry. iTab is a sorting index that holds previously 600a2a49dc9Sdrh ** seen combinations of the N values. A new entry is made in iTab 601a2a49dc9Sdrh ** if the current N values are new. 602a2a49dc9Sdrh ** 603a2a49dc9Sdrh ** A jump to addrRepeat is made and the N+1 values are popped from the 604a2a49dc9Sdrh ** stack if the top N elements are not distinct. 605a2a49dc9Sdrh */ 606a2a49dc9Sdrh static void codeDistinct( 6072dcef11bSdrh Parse *pParse, /* Parsing and code generating context */ 608a2a49dc9Sdrh int iTab, /* A sorting index used to test for distinctness */ 609a2a49dc9Sdrh int addrRepeat, /* Jump to here if not distinct */ 610477df4b3Sdrh int N, /* Number of elements */ 611a2a49dc9Sdrh int iMem /* First element */ 612a2a49dc9Sdrh ){ 6132dcef11bSdrh Vdbe *v; 6142dcef11bSdrh int r1; 6152dcef11bSdrh 6162dcef11bSdrh v = pParse->pVdbe; 6172dcef11bSdrh r1 = sqlite3GetTempReg(pParse); 618688852abSdrh sqlite3VdbeAddOp4Int(v, OP_Found, iTab, addrRepeat, iMem, N); VdbeCoverage(v); 6191db639ceSdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, iMem, N, r1); 6202dcef11bSdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, iTab, r1); 6212dcef11bSdrh sqlite3ReleaseTempReg(pParse, r1); 622a2a49dc9Sdrh } 623a2a49dc9Sdrh 624bb7dd683Sdrh #ifndef SQLITE_OMIT_SUBQUERY 625a2a49dc9Sdrh /* 626e305f43fSdrh ** Generate an error message when a SELECT is used within a subexpression 627e305f43fSdrh ** (example: "a IN (SELECT * FROM table)") but it has more than 1 result 628bb7dd683Sdrh ** column. We do this in a subroutine because the error used to occur 629bb7dd683Sdrh ** in multiple places. (The error only occurs in one place now, but we 630bb7dd683Sdrh ** retain the subroutine to minimize code disruption.) 631e305f43fSdrh */ 6326c8c8ce0Sdanielk1977 static int checkForMultiColumnSelectError( 6336c8c8ce0Sdanielk1977 Parse *pParse, /* Parse context. */ 6346c8c8ce0Sdanielk1977 SelectDest *pDest, /* Destination of SELECT results */ 6356c8c8ce0Sdanielk1977 int nExpr /* Number of result columns returned by SELECT */ 6366c8c8ce0Sdanielk1977 ){ 6376c8c8ce0Sdanielk1977 int eDest = pDest->eDest; 638e305f43fSdrh if( nExpr>1 && (eDest==SRT_Mem || eDest==SRT_Set) ){ 639e305f43fSdrh sqlite3ErrorMsg(pParse, "only a single result allowed for " 640e305f43fSdrh "a SELECT that is part of an expression"); 641e305f43fSdrh return 1; 642e305f43fSdrh }else{ 643e305f43fSdrh return 0; 644e305f43fSdrh } 645e305f43fSdrh } 646bb7dd683Sdrh #endif 647c99130fdSdrh 648c99130fdSdrh /* 6492282792aSdrh ** This routine generates the code for the inside of the inner loop 6502282792aSdrh ** of a SELECT. 65182c3d636Sdrh ** 652340309fdSdrh ** If srcTab is negative, then the pEList expressions 653340309fdSdrh ** are evaluated in order to get the data for this row. If srcTab is 654340309fdSdrh ** zero or more, then data is pulled from srcTab and pEList is used only 655340309fdSdrh ** to get number columns and the datatype for each column. 6562282792aSdrh */ 657d2b3e23bSdrh static void selectInnerLoop( 6582282792aSdrh Parse *pParse, /* The parser context */ 659df199a25Sdrh Select *p, /* The complete select statement being coded */ 6602282792aSdrh ExprList *pEList, /* List of values being extracted */ 66182c3d636Sdrh int srcTab, /* Pull data from this table */ 662079a3072Sdrh SortCtx *pSort, /* If not NULL, info on how to process ORDER BY */ 663e8e4af76Sdrh DistinctCtx *pDistinct, /* If not NULL, info on how to process DISTINCT */ 6646c8c8ce0Sdanielk1977 SelectDest *pDest, /* How to dispose of the results */ 6652282792aSdrh int iContinue, /* Jump here to continue with next row */ 666a9671a22Sdrh int iBreak /* Jump here to break out of the inner loop */ 6672282792aSdrh ){ 6682282792aSdrh Vdbe *v = pParse->pVdbe; 669d847eaadSdrh int i; 670ea48eb2eSdrh int hasDistinct; /* True if the DISTINCT keyword is present */ 671d847eaadSdrh int regResult; /* Start of memory holding result set */ 672d847eaadSdrh int eDest = pDest->eDest; /* How to dispose of results */ 6732b596da8Sdrh int iParm = pDest->iSDParm; /* First argument to disposal method */ 674d847eaadSdrh int nResultCol; /* Number of result columns */ 675fd0a2f97Sdrh int nPrefixReg = 0; /* Number of extra registers before regResult */ 67638640e15Sdrh 6771c767f0dSdrh assert( v ); 67838640e15Sdrh assert( pEList!=0 ); 679e8e4af76Sdrh hasDistinct = pDistinct ? pDistinct->eTnctType : WHERE_DISTINCT_NOOP; 680079a3072Sdrh if( pSort && pSort->pOrderBy==0 ) pSort = 0; 681079a3072Sdrh if( pSort==0 && !hasDistinct ){ 682a22a75e5Sdrh assert( iContinue!=0 ); 683aa9ce707Sdrh codeOffset(v, p->iOffset, iContinue); 684df199a25Sdrh } 685df199a25Sdrh 686967e8b73Sdrh /* Pull the requested columns. 6872282792aSdrh */ 688d847eaadSdrh nResultCol = pEList->nExpr; 68905a86c5cSdrh 6902b596da8Sdrh if( pDest->iSdst==0 ){ 691fd0a2f97Sdrh if( pSort ){ 69278d58432Sdan nPrefixReg = pSort->pOrderBy->nExpr; 69378d58432Sdan if( !(pSort->sortFlags & SORTFLAG_UseSorter) ) nPrefixReg++; 694fd0a2f97Sdrh pParse->nMem += nPrefixReg; 695fd0a2f97Sdrh } 6962b596da8Sdrh pDest->iSdst = pParse->nMem+1; 6970acb7e48Sdrh pParse->nMem += nResultCol; 69805a86c5cSdrh }else if( pDest->iSdst+nResultCol > pParse->nMem ){ 69905a86c5cSdrh /* This is an error condition that can result, for example, when a SELECT 70005a86c5cSdrh ** on the right-hand side of an INSERT contains more result columns than 70105a86c5cSdrh ** there are columns in the table on the left. The error will be caught 70205a86c5cSdrh ** and reported later. But we need to make sure enough memory is allocated 70305a86c5cSdrh ** to avoid other spurious errors in the meantime. */ 70405a86c5cSdrh pParse->nMem += nResultCol; 7051013c932Sdrh } 70605a86c5cSdrh pDest->nSdst = nResultCol; 7072b596da8Sdrh regResult = pDest->iSdst; 708340309fdSdrh if( srcTab>=0 ){ 709340309fdSdrh for(i=0; i<nResultCol; i++){ 710d847eaadSdrh sqlite3VdbeAddOp3(v, OP_Column, srcTab, i, regResult+i); 711340309fdSdrh VdbeComment((v, "%s", pEList->a[i].zName)); 71282c3d636Sdrh } 7139ed1dfa8Sdanielk1977 }else if( eDest!=SRT_Exists ){ 7149ed1dfa8Sdanielk1977 /* If the destination is an EXISTS(...) expression, the actual 7159ed1dfa8Sdanielk1977 ** values returned by the SELECT are not required. 7169ed1dfa8Sdanielk1977 */ 717d1a01edaSdrh sqlite3ExprCodeExprList(pParse, pEList, regResult, 7186295524eSdrh (eDest==SRT_Output||eDest==SRT_Coroutine)?SQLITE_ECEL_DUP:0); 719a2a49dc9Sdrh } 7202282792aSdrh 721daffd0e5Sdrh /* If the DISTINCT keyword was present on the SELECT statement 722daffd0e5Sdrh ** and this row has been seen before, then do not make this row 723daffd0e5Sdrh ** part of the result. 7242282792aSdrh */ 725ea48eb2eSdrh if( hasDistinct ){ 726e8e4af76Sdrh switch( pDistinct->eTnctType ){ 727e8e4af76Sdrh case WHERE_DISTINCT_ORDERED: { 728e8e4af76Sdrh VdbeOp *pOp; /* No longer required OpenEphemeral instr. */ 729e8e4af76Sdrh int iJump; /* Jump destination */ 730e8e4af76Sdrh int regPrev; /* Previous row content */ 731e8e4af76Sdrh 732e8e4af76Sdrh /* Allocate space for the previous row */ 733e8e4af76Sdrh regPrev = pParse->nMem+1; 734340309fdSdrh pParse->nMem += nResultCol; 735e8e4af76Sdrh 736e8e4af76Sdrh /* Change the OP_OpenEphemeral coded earlier to an OP_Null 737e8e4af76Sdrh ** sets the MEM_Cleared bit on the first register of the 738e8e4af76Sdrh ** previous value. This will cause the OP_Ne below to always 739e8e4af76Sdrh ** fail on the first iteration of the loop even if the first 740e8e4af76Sdrh ** row is all NULLs. 741e8e4af76Sdrh */ 742e8e4af76Sdrh sqlite3VdbeChangeToNoop(v, pDistinct->addrTnct); 743e8e4af76Sdrh pOp = sqlite3VdbeGetOp(v, pDistinct->addrTnct); 744e8e4af76Sdrh pOp->opcode = OP_Null; 745e8e4af76Sdrh pOp->p1 = 1; 746e8e4af76Sdrh pOp->p2 = regPrev; 747e8e4af76Sdrh 748340309fdSdrh iJump = sqlite3VdbeCurrentAddr(v) + nResultCol; 749340309fdSdrh for(i=0; i<nResultCol; i++){ 750e8e4af76Sdrh CollSeq *pColl = sqlite3ExprCollSeq(pParse, pEList->a[i].pExpr); 751340309fdSdrh if( i<nResultCol-1 ){ 752e8e4af76Sdrh sqlite3VdbeAddOp3(v, OP_Ne, regResult+i, iJump, regPrev+i); 753688852abSdrh VdbeCoverage(v); 754e8e4af76Sdrh }else{ 755e8e4af76Sdrh sqlite3VdbeAddOp3(v, OP_Eq, regResult+i, iContinue, regPrev+i); 756688852abSdrh VdbeCoverage(v); 757e8e4af76Sdrh } 758e8e4af76Sdrh sqlite3VdbeChangeP4(v, -1, (const char *)pColl, P4_COLLSEQ); 759e8e4af76Sdrh sqlite3VdbeChangeP5(v, SQLITE_NULLEQ); 760e8e4af76Sdrh } 761fcf2a775Sdrh assert( sqlite3VdbeCurrentAddr(v)==iJump || pParse->db->mallocFailed ); 762340309fdSdrh sqlite3VdbeAddOp3(v, OP_Copy, regResult, regPrev, nResultCol-1); 763e8e4af76Sdrh break; 764e8e4af76Sdrh } 765e8e4af76Sdrh 766e8e4af76Sdrh case WHERE_DISTINCT_UNIQUE: { 767e8e4af76Sdrh sqlite3VdbeChangeToNoop(v, pDistinct->addrTnct); 768e8e4af76Sdrh break; 769e8e4af76Sdrh } 770e8e4af76Sdrh 771e8e4af76Sdrh default: { 772e8e4af76Sdrh assert( pDistinct->eTnctType==WHERE_DISTINCT_UNORDERED ); 773340309fdSdrh codeDistinct(pParse, pDistinct->tabTnct, iContinue, nResultCol, regResult); 774e8e4af76Sdrh break; 775e8e4af76Sdrh } 776e8e4af76Sdrh } 777079a3072Sdrh if( pSort==0 ){ 778aa9ce707Sdrh codeOffset(v, p->iOffset, iContinue); 779ea48eb2eSdrh } 7802282792aSdrh } 78182c3d636Sdrh 782c926afbcSdrh switch( eDest ){ 78382c3d636Sdrh /* In this mode, write each query result to the key of the temporary 78482c3d636Sdrh ** table iParm. 7852282792aSdrh */ 78613449892Sdrh #ifndef SQLITE_OMIT_COMPOUND_SELECT 787c926afbcSdrh case SRT_Union: { 7889cbf3425Sdrh int r1; 7899cbf3425Sdrh r1 = sqlite3GetTempReg(pParse); 790340309fdSdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, regResult, nResultCol, r1); 7919cbf3425Sdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, r1); 7929cbf3425Sdrh sqlite3ReleaseTempReg(pParse, r1); 793c926afbcSdrh break; 794c926afbcSdrh } 79582c3d636Sdrh 79682c3d636Sdrh /* Construct a record from the query result, but instead of 79782c3d636Sdrh ** saving that record, use it as a key to delete elements from 79882c3d636Sdrh ** the temporary table iParm. 79982c3d636Sdrh */ 800c926afbcSdrh case SRT_Except: { 801340309fdSdrh sqlite3VdbeAddOp3(v, OP_IdxDelete, iParm, regResult, nResultCol); 802c926afbcSdrh break; 803c926afbcSdrh } 804781def29Sdrh #endif /* SQLITE_OMIT_COMPOUND_SELECT */ 8055338a5f7Sdanielk1977 8065338a5f7Sdanielk1977 /* Store the result as data using a unique key. 8075338a5f7Sdanielk1977 */ 8088e1ee88cSdrh case SRT_Fifo: 8098e1ee88cSdrh case SRT_DistFifo: 8105338a5f7Sdanielk1977 case SRT_Table: 811b9bb7c18Sdrh case SRT_EphemTab: { 812fd0a2f97Sdrh int r1 = sqlite3GetTempRange(pParse, nPrefixReg+1); 813373cc2ddSdrh testcase( eDest==SRT_Table ); 814373cc2ddSdrh testcase( eDest==SRT_EphemTab ); 815fd0a2f97Sdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, regResult, nResultCol, r1+nPrefixReg); 8168ce7184bSdan #ifndef SQLITE_OMIT_CTE 8178e1ee88cSdrh if( eDest==SRT_DistFifo ){ 8188e1ee88cSdrh /* If the destination is DistFifo, then cursor (iParm+1) is open 8198ce7184bSdan ** on an ephemeral index. If the current row is already present 8208ce7184bSdan ** in the index, do not write it to the output. If not, add the 8218ce7184bSdan ** current row to the index and proceed with writing it to the 8228ce7184bSdan ** output table as well. */ 8238ce7184bSdan int addr = sqlite3VdbeCurrentAddr(v) + 4; 824688852abSdrh sqlite3VdbeAddOp4Int(v, OP_Found, iParm+1, addr, r1, 0); VdbeCoverage(v); 8258ce7184bSdan sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm+1, r1); 826079a3072Sdrh assert( pSort==0 ); 8278ce7184bSdan } 8288ce7184bSdan #endif 829079a3072Sdrh if( pSort ){ 830fd0a2f97Sdrh pushOntoSorter(pParse, pSort, p, r1+nPrefixReg, 1, nPrefixReg); 8315338a5f7Sdanielk1977 }else{ 832b7654111Sdrh int r2 = sqlite3GetTempReg(pParse); 833b7654111Sdrh sqlite3VdbeAddOp2(v, OP_NewRowid, iParm, r2); 834b7654111Sdrh sqlite3VdbeAddOp3(v, OP_Insert, iParm, r1, r2); 835b7654111Sdrh sqlite3VdbeChangeP5(v, OPFLAG_APPEND); 836b7654111Sdrh sqlite3ReleaseTempReg(pParse, r2); 8375338a5f7Sdanielk1977 } 838fd0a2f97Sdrh sqlite3ReleaseTempRange(pParse, r1, nPrefixReg+1); 8395338a5f7Sdanielk1977 break; 8405338a5f7Sdanielk1977 } 8412282792aSdrh 84293758c8dSdanielk1977 #ifndef SQLITE_OMIT_SUBQUERY 8432282792aSdrh /* If we are creating a set for an "expr IN (SELECT ...)" construct, 8442282792aSdrh ** then there should be a single item on the stack. Write this 8452282792aSdrh ** item into the set table with bogus data. 8462282792aSdrh */ 847c926afbcSdrh case SRT_Set: { 848340309fdSdrh assert( nResultCol==1 ); 849634d81deSdrh pDest->affSdst = 850634d81deSdrh sqlite3CompareAffinity(pEList->a[0].pExpr, pDest->affSdst); 851079a3072Sdrh if( pSort ){ 852de941c60Sdrh /* At first glance you would think we could optimize out the 853de941c60Sdrh ** ORDER BY in this case since the order of entries in the set 854de941c60Sdrh ** does not matter. But there might be a LIMIT clause, in which 855de941c60Sdrh ** case the order does matter */ 856fd0a2f97Sdrh pushOntoSorter(pParse, pSort, p, regResult, 1, nPrefixReg); 857c926afbcSdrh }else{ 858b7654111Sdrh int r1 = sqlite3GetTempReg(pParse); 859634d81deSdrh sqlite3VdbeAddOp4(v, OP_MakeRecord, regResult,1,r1, &pDest->affSdst, 1); 860da250ea5Sdrh sqlite3ExprCacheAffinityChange(pParse, regResult, 1); 861b7654111Sdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, r1); 862b7654111Sdrh sqlite3ReleaseTempReg(pParse, r1); 863c926afbcSdrh } 864c926afbcSdrh break; 865c926afbcSdrh } 86682c3d636Sdrh 867504b6989Sdrh /* If any row exist in the result set, record that fact and abort. 868ec7429aeSdrh */ 869ec7429aeSdrh case SRT_Exists: { 8704c583128Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 1, iParm); 871ec7429aeSdrh /* The LIMIT clause will terminate the loop for us */ 872ec7429aeSdrh break; 873ec7429aeSdrh } 874ec7429aeSdrh 8752282792aSdrh /* If this is a scalar select that is part of an expression, then 8762282792aSdrh ** store the results in the appropriate memory cell and break out 8772282792aSdrh ** of the scan loop. 8782282792aSdrh */ 879c926afbcSdrh case SRT_Mem: { 880340309fdSdrh assert( nResultCol==1 ); 881079a3072Sdrh if( pSort ){ 882fd0a2f97Sdrh pushOntoSorter(pParse, pSort, p, regResult, 1, nPrefixReg); 883c926afbcSdrh }else{ 88453932ce8Sdrh assert( regResult==iParm ); 885ec7429aeSdrh /* The LIMIT clause will jump out of the loop for us */ 886c926afbcSdrh } 887c926afbcSdrh break; 888c926afbcSdrh } 88993758c8dSdanielk1977 #endif /* #ifndef SQLITE_OMIT_SUBQUERY */ 8902282792aSdrh 89181cf13ecSdrh case SRT_Coroutine: /* Send data to a co-routine */ 89281cf13ecSdrh case SRT_Output: { /* Return the results */ 893373cc2ddSdrh testcase( eDest==SRT_Coroutine ); 894373cc2ddSdrh testcase( eDest==SRT_Output ); 895079a3072Sdrh if( pSort ){ 896fd0a2f97Sdrh pushOntoSorter(pParse, pSort, p, regResult, nResultCol, nPrefixReg); 897e00ee6ebSdrh }else if( eDest==SRT_Coroutine ){ 8982b596da8Sdrh sqlite3VdbeAddOp1(v, OP_Yield, pDest->iSDParm); 899c182d163Sdrh }else{ 900340309fdSdrh sqlite3VdbeAddOp2(v, OP_ResultRow, regResult, nResultCol); 901340309fdSdrh sqlite3ExprCacheAffinityChange(pParse, regResult, nResultCol); 902ac82fcf5Sdrh } 903142e30dfSdrh break; 904142e30dfSdrh } 905142e30dfSdrh 906fe1c6bb9Sdrh #ifndef SQLITE_OMIT_CTE 907fe1c6bb9Sdrh /* Write the results into a priority queue that is order according to 908fe1c6bb9Sdrh ** pDest->pOrderBy (in pSO). pDest->iSDParm (in iParm) is the cursor for an 909fe1c6bb9Sdrh ** index with pSO->nExpr+2 columns. Build a key using pSO for the first 910fe1c6bb9Sdrh ** pSO->nExpr columns, then make sure all keys are unique by adding a 911fe1c6bb9Sdrh ** final OP_Sequence column. The last column is the record as a blob. 912fe1c6bb9Sdrh */ 913fe1c6bb9Sdrh case SRT_DistQueue: 914fe1c6bb9Sdrh case SRT_Queue: { 915fe1c6bb9Sdrh int nKey; 916fe1c6bb9Sdrh int r1, r2, r3; 917fe1c6bb9Sdrh int addrTest = 0; 918fe1c6bb9Sdrh ExprList *pSO; 919fe1c6bb9Sdrh pSO = pDest->pOrderBy; 920fe1c6bb9Sdrh assert( pSO ); 921fe1c6bb9Sdrh nKey = pSO->nExpr; 922fe1c6bb9Sdrh r1 = sqlite3GetTempReg(pParse); 923fe1c6bb9Sdrh r2 = sqlite3GetTempRange(pParse, nKey+2); 924fe1c6bb9Sdrh r3 = r2+nKey+1; 925fe1c6bb9Sdrh if( eDest==SRT_DistQueue ){ 926fe1c6bb9Sdrh /* If the destination is DistQueue, then cursor (iParm+1) is open 927fe1c6bb9Sdrh ** on a second ephemeral index that holds all values every previously 9287e4efaecSdrh ** added to the queue. */ 9297e4efaecSdrh addrTest = sqlite3VdbeAddOp4Int(v, OP_Found, iParm+1, 0, 9307e4efaecSdrh regResult, nResultCol); 931688852abSdrh VdbeCoverage(v); 9327e4efaecSdrh } 9337e4efaecSdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, regResult, nResultCol, r3); 9347e4efaecSdrh if( eDest==SRT_DistQueue ){ 935fe1c6bb9Sdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm+1, r3); 936cfe24586Sdan sqlite3VdbeChangeP5(v, OPFLAG_USESEEKRESULT); 937fe1c6bb9Sdrh } 938fe1c6bb9Sdrh for(i=0; i<nKey; i++){ 939fe1c6bb9Sdrh sqlite3VdbeAddOp2(v, OP_SCopy, 940fe1c6bb9Sdrh regResult + pSO->a[i].u.x.iOrderByCol - 1, 941fe1c6bb9Sdrh r2+i); 942fe1c6bb9Sdrh } 943fe1c6bb9Sdrh sqlite3VdbeAddOp2(v, OP_Sequence, iParm, r2+nKey); 944fe1c6bb9Sdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, r2, nKey+2, r1); 945fe1c6bb9Sdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, r1); 946fe1c6bb9Sdrh if( addrTest ) sqlite3VdbeJumpHere(v, addrTest); 947fe1c6bb9Sdrh sqlite3ReleaseTempReg(pParse, r1); 948fe1c6bb9Sdrh sqlite3ReleaseTempRange(pParse, r2, nKey+2); 949fe1c6bb9Sdrh break; 950fe1c6bb9Sdrh } 951fe1c6bb9Sdrh #endif /* SQLITE_OMIT_CTE */ 952fe1c6bb9Sdrh 953fe1c6bb9Sdrh 954fe1c6bb9Sdrh 9556a67fe8eSdanielk1977 #if !defined(SQLITE_OMIT_TRIGGER) 956d7489c39Sdrh /* Discard the results. This is used for SELECT statements inside 957d7489c39Sdrh ** the body of a TRIGGER. The purpose of such selects is to call 958d7489c39Sdrh ** user-defined functions that have side effects. We do not care 959d7489c39Sdrh ** about the actual results of the select. 960d7489c39Sdrh */ 961c926afbcSdrh default: { 962f46f905aSdrh assert( eDest==SRT_Discard ); 963c926afbcSdrh break; 964c926afbcSdrh } 96593758c8dSdanielk1977 #endif 966c926afbcSdrh } 967ec7429aeSdrh 9685e87be87Sdrh /* Jump to the end of the loop if the LIMIT is reached. Except, if 9695e87be87Sdrh ** there is a sorter, in which case the sorter has already limited 9705e87be87Sdrh ** the output for us. 971ec7429aeSdrh */ 972079a3072Sdrh if( pSort==0 && p->iLimit ){ 973688852abSdrh sqlite3VdbeAddOp3(v, OP_IfZero, p->iLimit, iBreak, -1); VdbeCoverage(v); 974ec7429aeSdrh } 97582c3d636Sdrh } 97682c3d636Sdrh 97782c3d636Sdrh /* 978ad124329Sdrh ** Allocate a KeyInfo object sufficient for an index of N key columns and 979ad124329Sdrh ** X extra columns. 980323df790Sdrh */ 981ad124329Sdrh KeyInfo *sqlite3KeyInfoAlloc(sqlite3 *db, int N, int X){ 9822ec2fb22Sdrh KeyInfo *p = sqlite3DbMallocZero(0, 983ad124329Sdrh sizeof(KeyInfo) + (N+X)*(sizeof(CollSeq*)+1)); 984323df790Sdrh if( p ){ 985ad124329Sdrh p->aSortOrder = (u8*)&p->aColl[N+X]; 986323df790Sdrh p->nField = (u16)N; 987ad124329Sdrh p->nXField = (u16)X; 988323df790Sdrh p->enc = ENC(db); 989323df790Sdrh p->db = db; 9902ec2fb22Sdrh p->nRef = 1; 9912ec2fb22Sdrh }else{ 9922ec2fb22Sdrh db->mallocFailed = 1; 993323df790Sdrh } 994323df790Sdrh return p; 995323df790Sdrh } 996323df790Sdrh 997323df790Sdrh /* 9982ec2fb22Sdrh ** Deallocate a KeyInfo object 9992ec2fb22Sdrh */ 10002ec2fb22Sdrh void sqlite3KeyInfoUnref(KeyInfo *p){ 10012ec2fb22Sdrh if( p ){ 10022ec2fb22Sdrh assert( p->nRef>0 ); 10032ec2fb22Sdrh p->nRef--; 1004c6efe12dSmistachkin if( p->nRef==0 ) sqlite3DbFree(0, p); 10052ec2fb22Sdrh } 10062ec2fb22Sdrh } 10072ec2fb22Sdrh 10082ec2fb22Sdrh /* 10092ec2fb22Sdrh ** Make a new pointer to a KeyInfo object 10102ec2fb22Sdrh */ 10112ec2fb22Sdrh KeyInfo *sqlite3KeyInfoRef(KeyInfo *p){ 10122ec2fb22Sdrh if( p ){ 10132ec2fb22Sdrh assert( p->nRef>0 ); 10142ec2fb22Sdrh p->nRef++; 10152ec2fb22Sdrh } 10162ec2fb22Sdrh return p; 10172ec2fb22Sdrh } 10182ec2fb22Sdrh 10192ec2fb22Sdrh #ifdef SQLITE_DEBUG 10202ec2fb22Sdrh /* 10212ec2fb22Sdrh ** Return TRUE if a KeyInfo object can be change. The KeyInfo object 10222ec2fb22Sdrh ** can only be changed if this is just a single reference to the object. 10232ec2fb22Sdrh ** 10242ec2fb22Sdrh ** This routine is used only inside of assert() statements. 10252ec2fb22Sdrh */ 10262ec2fb22Sdrh int sqlite3KeyInfoIsWriteable(KeyInfo *p){ return p->nRef==1; } 10272ec2fb22Sdrh #endif /* SQLITE_DEBUG */ 10282ec2fb22Sdrh 10292ec2fb22Sdrh /* 1030dece1a84Sdrh ** Given an expression list, generate a KeyInfo structure that records 1031dece1a84Sdrh ** the collating sequence for each expression in that expression list. 1032dece1a84Sdrh ** 10330342b1f5Sdrh ** If the ExprList is an ORDER BY or GROUP BY clause then the resulting 10340342b1f5Sdrh ** KeyInfo structure is appropriate for initializing a virtual index to 10350342b1f5Sdrh ** implement that clause. If the ExprList is the result set of a SELECT 10360342b1f5Sdrh ** then the KeyInfo structure is appropriate for initializing a virtual 10370342b1f5Sdrh ** index to implement a DISTINCT test. 10380342b1f5Sdrh ** 103960ec914cSpeter.d.reid ** Space to hold the KeyInfo structure is obtained from malloc. The calling 1040dece1a84Sdrh ** function is responsible for seeing that this structure is eventually 10412ec2fb22Sdrh ** freed. 1042dece1a84Sdrh */ 1043079a3072Sdrh static KeyInfo *keyInfoFromExprList( 1044079a3072Sdrh Parse *pParse, /* Parsing context */ 1045079a3072Sdrh ExprList *pList, /* Form the KeyInfo object from this ExprList */ 1046079a3072Sdrh int iStart, /* Begin with this column of pList */ 1047079a3072Sdrh int nExtra /* Add this many extra columns to the end */ 1048079a3072Sdrh ){ 1049dece1a84Sdrh int nExpr; 1050dece1a84Sdrh KeyInfo *pInfo; 1051dece1a84Sdrh struct ExprList_item *pItem; 1052323df790Sdrh sqlite3 *db = pParse->db; 1053dece1a84Sdrh int i; 1054dece1a84Sdrh 1055dece1a84Sdrh nExpr = pList->nExpr; 1056079a3072Sdrh pInfo = sqlite3KeyInfoAlloc(db, nExpr+nExtra-iStart, 1); 1057dece1a84Sdrh if( pInfo ){ 10582ec2fb22Sdrh assert( sqlite3KeyInfoIsWriteable(pInfo) ); 10596284db90Sdrh for(i=iStart, pItem=pList->a+iStart; i<nExpr; i++, pItem++){ 1060dece1a84Sdrh CollSeq *pColl; 1061dece1a84Sdrh pColl = sqlite3ExprCollSeq(pParse, pItem->pExpr); 1062323df790Sdrh if( !pColl ) pColl = db->pDfltColl; 10636284db90Sdrh pInfo->aColl[i-iStart] = pColl; 10646284db90Sdrh pInfo->aSortOrder[i-iStart] = pItem->sortOrder; 1065dece1a84Sdrh } 1066dece1a84Sdrh } 1067dece1a84Sdrh return pInfo; 1068dece1a84Sdrh } 1069dece1a84Sdrh 10707f61e92cSdan #ifndef SQLITE_OMIT_COMPOUND_SELECT 10717f61e92cSdan /* 10727f61e92cSdan ** Name of the connection operator, used for error messages. 10737f61e92cSdan */ 10747f61e92cSdan static const char *selectOpName(int id){ 10757f61e92cSdan char *z; 10767f61e92cSdan switch( id ){ 10777f61e92cSdan case TK_ALL: z = "UNION ALL"; break; 10787f61e92cSdan case TK_INTERSECT: z = "INTERSECT"; break; 10797f61e92cSdan case TK_EXCEPT: z = "EXCEPT"; break; 10807f61e92cSdan default: z = "UNION"; break; 10817f61e92cSdan } 10827f61e92cSdan return z; 10837f61e92cSdan } 10847f61e92cSdan #endif /* SQLITE_OMIT_COMPOUND_SELECT */ 10857f61e92cSdan 10862ce22453Sdan #ifndef SQLITE_OMIT_EXPLAIN 108717c0bc0cSdan /* 108817c0bc0cSdan ** Unless an "EXPLAIN QUERY PLAN" command is being processed, this function 108917c0bc0cSdan ** is a no-op. Otherwise, it adds a single row of output to the EQP result, 109017c0bc0cSdan ** where the caption is of the form: 109117c0bc0cSdan ** 109217c0bc0cSdan ** "USE TEMP B-TREE FOR xxx" 109317c0bc0cSdan ** 109417c0bc0cSdan ** where xxx is one of "DISTINCT", "ORDER BY" or "GROUP BY". Exactly which 109517c0bc0cSdan ** is determined by the zUsage argument. 109617c0bc0cSdan */ 10972ce22453Sdan static void explainTempTable(Parse *pParse, const char *zUsage){ 10982ce22453Sdan if( pParse->explain==2 ){ 10992ce22453Sdan Vdbe *v = pParse->pVdbe; 11002ce22453Sdan char *zMsg = sqlite3MPrintf(pParse->db, "USE TEMP B-TREE FOR %s", zUsage); 11012ce22453Sdan sqlite3VdbeAddOp4(v, OP_Explain, pParse->iSelectId, 0, 0, zMsg, P4_DYNAMIC); 11022ce22453Sdan } 11032ce22453Sdan } 110417c0bc0cSdan 110517c0bc0cSdan /* 1106bb2b4418Sdan ** Assign expression b to lvalue a. A second, no-op, version of this macro 1107bb2b4418Sdan ** is provided when SQLITE_OMIT_EXPLAIN is defined. This allows the code 1108bb2b4418Sdan ** in sqlite3Select() to assign values to structure member variables that 1109bb2b4418Sdan ** only exist if SQLITE_OMIT_EXPLAIN is not defined without polluting the 1110bb2b4418Sdan ** code with #ifndef directives. 1111bb2b4418Sdan */ 1112bb2b4418Sdan # define explainSetInteger(a, b) a = b 1113bb2b4418Sdan 1114bb2b4418Sdan #else 1115bb2b4418Sdan /* No-op versions of the explainXXX() functions and macros. */ 1116bb2b4418Sdan # define explainTempTable(y,z) 1117bb2b4418Sdan # define explainSetInteger(y,z) 1118bb2b4418Sdan #endif 1119bb2b4418Sdan 1120bb2b4418Sdan #if !defined(SQLITE_OMIT_EXPLAIN) && !defined(SQLITE_OMIT_COMPOUND_SELECT) 1121bb2b4418Sdan /* 11227f61e92cSdan ** Unless an "EXPLAIN QUERY PLAN" command is being processed, this function 11237f61e92cSdan ** is a no-op. Otherwise, it adds a single row of output to the EQP result, 11247f61e92cSdan ** where the caption is of one of the two forms: 11257f61e92cSdan ** 11267f61e92cSdan ** "COMPOSITE SUBQUERIES iSub1 and iSub2 (op)" 11277f61e92cSdan ** "COMPOSITE SUBQUERIES iSub1 and iSub2 USING TEMP B-TREE (op)" 11287f61e92cSdan ** 11297f61e92cSdan ** where iSub1 and iSub2 are the integers passed as the corresponding 11307f61e92cSdan ** function parameters, and op is the text representation of the parameter 11317f61e92cSdan ** of the same name. The parameter "op" must be one of TK_UNION, TK_EXCEPT, 11327f61e92cSdan ** TK_INTERSECT or TK_ALL. The first form is used if argument bUseTmp is 11337f61e92cSdan ** false, or the second form if it is true. 11347f61e92cSdan */ 11357f61e92cSdan static void explainComposite( 11367f61e92cSdan Parse *pParse, /* Parse context */ 11377f61e92cSdan int op, /* One of TK_UNION, TK_EXCEPT etc. */ 11387f61e92cSdan int iSub1, /* Subquery id 1 */ 11397f61e92cSdan int iSub2, /* Subquery id 2 */ 11407f61e92cSdan int bUseTmp /* True if a temp table was used */ 11417f61e92cSdan ){ 11427f61e92cSdan assert( op==TK_UNION || op==TK_EXCEPT || op==TK_INTERSECT || op==TK_ALL ); 11437f61e92cSdan if( pParse->explain==2 ){ 11447f61e92cSdan Vdbe *v = pParse->pVdbe; 11457f61e92cSdan char *zMsg = sqlite3MPrintf( 114630969d3fSdan pParse->db, "COMPOUND SUBQUERIES %d AND %d %s(%s)", iSub1, iSub2, 11477f61e92cSdan bUseTmp?"USING TEMP B-TREE ":"", selectOpName(op) 11487f61e92cSdan ); 11497f61e92cSdan sqlite3VdbeAddOp4(v, OP_Explain, pParse->iSelectId, 0, 0, zMsg, P4_DYNAMIC); 11507f61e92cSdan } 11517f61e92cSdan } 11522ce22453Sdan #else 115317c0bc0cSdan /* No-op versions of the explainXXX() functions and macros. */ 11547f61e92cSdan # define explainComposite(v,w,x,y,z) 11552ce22453Sdan #endif 1156dece1a84Sdrh 1157dece1a84Sdrh /* 1158d8bc7086Sdrh ** If the inner loop was generated using a non-null pOrderBy argument, 1159d8bc7086Sdrh ** then the results were placed in a sorter. After the loop is terminated 1160d8bc7086Sdrh ** we need to run the sorter and output the results. The following 1161d8bc7086Sdrh ** routine generates the code needed to do that. 1162d8bc7086Sdrh */ 1163c926afbcSdrh static void generateSortTail( 1164cdd536f0Sdrh Parse *pParse, /* Parsing context */ 1165c926afbcSdrh Select *p, /* The SELECT statement */ 1166079a3072Sdrh SortCtx *pSort, /* Information on the ORDER BY clause */ 1167c926afbcSdrh int nColumn, /* Number of columns of data */ 11686c8c8ce0Sdanielk1977 SelectDest *pDest /* Write the sorted results here */ 1169c926afbcSdrh ){ 1170ddba0c22Sdrh Vdbe *v = pParse->pVdbe; /* The prepared statement */ 1171dc5ea5c7Sdrh int addrBreak = sqlite3VdbeMakeLabel(v); /* Jump here to exit loop */ 1172dc5ea5c7Sdrh int addrContinue = sqlite3VdbeMakeLabel(v); /* Jump here for next cycle */ 1173d8bc7086Sdrh int addr; 1174079a3072Sdrh int addrOnce = 0; 11750342b1f5Sdrh int iTab; 1176079a3072Sdrh ExprList *pOrderBy = pSort->pOrderBy; 11776c8c8ce0Sdanielk1977 int eDest = pDest->eDest; 11782b596da8Sdrh int iParm = pDest->iSDParm; 11792d401ab8Sdrh int regRow; 11802d401ab8Sdrh int regRowid; 1181079a3072Sdrh int nKey; 1182f45f2326Sdrh int iSortTab; /* Sorter cursor to read from */ 1183f45f2326Sdrh int nSortData; /* Trailing values to read from sorter */ 1184f45f2326Sdrh u8 p5; /* p5 parameter for 1st OP_Column */ 1185f45f2326Sdrh int i; 118678d58432Sdan int bSeq; /* True if sorter record includes seq. no. */ 118770f624c3Sdrh #ifdef SQLITE_ENABLE_EXPLAIN_COMMENTS 118870f624c3Sdrh struct ExprList_item *aOutEx = p->pEList->a; 118970f624c3Sdrh #endif 11902d401ab8Sdrh 1191079a3072Sdrh if( pSort->labelBkOut ){ 1192079a3072Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, pSort->regReturn, pSort->labelBkOut); 1193079a3072Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, addrBreak); 1194079a3072Sdrh sqlite3VdbeResolveLabel(v, pSort->labelBkOut); 1195079a3072Sdrh } 1196079a3072Sdrh iTab = pSort->iECursor; 11977d10d5a6Sdrh if( eDest==SRT_Output || eDest==SRT_Coroutine ){ 11983e9ca094Sdrh regRowid = 0; 1199f45f2326Sdrh regRow = pDest->iSdst; 1200f45f2326Sdrh nSortData = nColumn; 12013e9ca094Sdrh }else{ 12023e9ca094Sdrh regRowid = sqlite3GetTempReg(pParse); 1203f45f2326Sdrh regRow = sqlite3GetTempReg(pParse); 1204f45f2326Sdrh nSortData = 1; 1205cdd536f0Sdrh } 1206079a3072Sdrh nKey = pOrderBy->nExpr - pSort->nOBSat; 1207079a3072Sdrh if( pSort->sortFlags & SORTFLAG_UseSorter ){ 1208c2bb3282Sdrh int regSortOut = ++pParse->nMem; 1209f45f2326Sdrh iSortTab = pParse->nTab++; 121083553eefSdrh if( pSort->labelBkOut ){ 121183553eefSdrh addrOnce = sqlite3CodeOnce(pParse); VdbeCoverage(v); 121283553eefSdrh } 1213f45f2326Sdrh sqlite3VdbeAddOp3(v, OP_OpenPseudo, iSortTab, regSortOut, nKey+1+nSortData); 1214079a3072Sdrh if( addrOnce ) sqlite3VdbeJumpHere(v, addrOnce); 1215c6aff30cSdrh addr = 1 + sqlite3VdbeAddOp2(v, OP_SorterSort, iTab, addrBreak); 1216688852abSdrh VdbeCoverage(v); 1217aa9ce707Sdrh codeOffset(v, p->iOffset, addrContinue); 1218c6aff30cSdrh sqlite3VdbeAddOp2(v, OP_SorterData, iTab, regSortOut); 1219f45f2326Sdrh p5 = OPFLAG_CLEARCACHE; 122078d58432Sdan bSeq = 0; 1221c6aff30cSdrh }else{ 1222688852abSdrh addr = 1 + sqlite3VdbeAddOp2(v, OP_Sort, iTab, addrBreak); VdbeCoverage(v); 1223aa9ce707Sdrh codeOffset(v, p->iOffset, addrContinue); 1224f45f2326Sdrh iSortTab = iTab; 1225f45f2326Sdrh p5 = 0; 122678d58432Sdan bSeq = 1; 1227f45f2326Sdrh } 1228f45f2326Sdrh for(i=0; i<nSortData; i++){ 122978d58432Sdan sqlite3VdbeAddOp3(v, OP_Column, iSortTab, nKey+bSeq+i, regRow+i); 1230f45f2326Sdrh if( i==0 ) sqlite3VdbeChangeP5(v, p5); 123170f624c3Sdrh VdbeComment((v, "%s", aOutEx[i].zName ? aOutEx[i].zName : aOutEx[i].zSpan)); 1232c6aff30cSdrh } 1233c926afbcSdrh switch( eDest ){ 1234c926afbcSdrh case SRT_Table: 1235b9bb7c18Sdrh case SRT_EphemTab: { 12361c767f0dSdrh testcase( eDest==SRT_Table ); 12371c767f0dSdrh testcase( eDest==SRT_EphemTab ); 12382d401ab8Sdrh sqlite3VdbeAddOp2(v, OP_NewRowid, iParm, regRowid); 12392d401ab8Sdrh sqlite3VdbeAddOp3(v, OP_Insert, iParm, regRow, regRowid); 12402d401ab8Sdrh sqlite3VdbeChangeP5(v, OPFLAG_APPEND); 1241c926afbcSdrh break; 1242c926afbcSdrh } 124393758c8dSdanielk1977 #ifndef SQLITE_OMIT_SUBQUERY 1244c926afbcSdrh case SRT_Set: { 1245c926afbcSdrh assert( nColumn==1 ); 1246634d81deSdrh sqlite3VdbeAddOp4(v, OP_MakeRecord, regRow, 1, regRowid, 1247634d81deSdrh &pDest->affSdst, 1); 1248da250ea5Sdrh sqlite3ExprCacheAffinityChange(pParse, regRow, 1); 1249a7a8e14bSdanielk1977 sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, regRowid); 1250c926afbcSdrh break; 1251c926afbcSdrh } 1252c926afbcSdrh case SRT_Mem: { 1253c926afbcSdrh assert( nColumn==1 ); 1254b21e7c70Sdrh sqlite3ExprCodeMove(pParse, regRow, iParm, 1); 1255ec7429aeSdrh /* The LIMIT clause will terminate the loop for us */ 1256c926afbcSdrh break; 1257c926afbcSdrh } 125893758c8dSdanielk1977 #endif 1259373cc2ddSdrh default: { 1260373cc2ddSdrh assert( eDest==SRT_Output || eDest==SRT_Coroutine ); 12611c767f0dSdrh testcase( eDest==SRT_Output ); 12621c767f0dSdrh testcase( eDest==SRT_Coroutine ); 12637d10d5a6Sdrh if( eDest==SRT_Output ){ 12642b596da8Sdrh sqlite3VdbeAddOp2(v, OP_ResultRow, pDest->iSdst, nColumn); 12652b596da8Sdrh sqlite3ExprCacheAffinityChange(pParse, pDest->iSdst, nColumn); 1266a9671a22Sdrh }else{ 12672b596da8Sdrh sqlite3VdbeAddOp1(v, OP_Yield, pDest->iSDParm); 1268ce665cf6Sdrh } 1269ac82fcf5Sdrh break; 1270ac82fcf5Sdrh } 1271c926afbcSdrh } 1272f45f2326Sdrh if( regRowid ){ 12732d401ab8Sdrh sqlite3ReleaseTempReg(pParse, regRow); 12742d401ab8Sdrh sqlite3ReleaseTempReg(pParse, regRowid); 1275f45f2326Sdrh } 1276ec7429aeSdrh /* The bottom of the loop 1277ec7429aeSdrh */ 1278dc5ea5c7Sdrh sqlite3VdbeResolveLabel(v, addrContinue); 1279079a3072Sdrh if( pSort->sortFlags & SORTFLAG_UseSorter ){ 1280688852abSdrh sqlite3VdbeAddOp2(v, OP_SorterNext, iTab, addr); VdbeCoverage(v); 1281c6aff30cSdrh }else{ 1282688852abSdrh sqlite3VdbeAddOp2(v, OP_Next, iTab, addr); VdbeCoverage(v); 1283c6aff30cSdrh } 1284079a3072Sdrh if( pSort->regReturn ) sqlite3VdbeAddOp1(v, OP_Return, pSort->regReturn); 1285dc5ea5c7Sdrh sqlite3VdbeResolveLabel(v, addrBreak); 1286d8bc7086Sdrh } 1287d8bc7086Sdrh 1288d8bc7086Sdrh /* 1289517eb646Sdanielk1977 ** Return a pointer to a string containing the 'declaration type' of the 1290517eb646Sdanielk1977 ** expression pExpr. The string may be treated as static by the caller. 1291e78e8284Sdrh ** 12925f3e5e74Sdrh ** Also try to estimate the size of the returned value and return that 12935f3e5e74Sdrh ** result in *pEstWidth. 12945f3e5e74Sdrh ** 1295955de52cSdanielk1977 ** The declaration type is the exact datatype definition extracted from the 1296955de52cSdanielk1977 ** original CREATE TABLE statement if the expression is a column. The 1297955de52cSdanielk1977 ** declaration type for a ROWID field is INTEGER. Exactly when an expression 1298955de52cSdanielk1977 ** is considered a column can be complex in the presence of subqueries. The 1299955de52cSdanielk1977 ** result-set expression in all of the following SELECT statements is 1300955de52cSdanielk1977 ** considered a column by this function. 1301e78e8284Sdrh ** 1302955de52cSdanielk1977 ** SELECT col FROM tbl; 1303955de52cSdanielk1977 ** SELECT (SELECT col FROM tbl; 1304955de52cSdanielk1977 ** SELECT (SELECT col FROM tbl); 1305955de52cSdanielk1977 ** SELECT abc FROM (SELECT col AS abc FROM tbl); 1306955de52cSdanielk1977 ** 1307955de52cSdanielk1977 ** The declaration type for any expression other than a column is NULL. 13085f3e5e74Sdrh ** 13095f3e5e74Sdrh ** This routine has either 3 or 6 parameters depending on whether or not 13105f3e5e74Sdrh ** the SQLITE_ENABLE_COLUMN_METADATA compile-time option is used. 1311fcb78a49Sdrh */ 13125f3e5e74Sdrh #ifdef SQLITE_ENABLE_COLUMN_METADATA 13135f3e5e74Sdrh # define columnType(A,B,C,D,E,F) columnTypeImpl(A,B,C,D,E,F) 13145f3e5e74Sdrh static const char *columnTypeImpl( 1315955de52cSdanielk1977 NameContext *pNC, 1316955de52cSdanielk1977 Expr *pExpr, 13175f3e5e74Sdrh const char **pzOrigDb, 13185f3e5e74Sdrh const char **pzOrigTab, 13195f3e5e74Sdrh const char **pzOrigCol, 13205f3e5e74Sdrh u8 *pEstWidth 1321955de52cSdanielk1977 ){ 13225f3e5e74Sdrh char const *zOrigDb = 0; 13235f3e5e74Sdrh char const *zOrigTab = 0; 13245f3e5e74Sdrh char const *zOrigCol = 0; 13255f3e5e74Sdrh #else /* if !defined(SQLITE_ENABLE_COLUMN_METADATA) */ 13265f3e5e74Sdrh # define columnType(A,B,C,D,E,F) columnTypeImpl(A,B,F) 13275f3e5e74Sdrh static const char *columnTypeImpl( 13285f3e5e74Sdrh NameContext *pNC, 13295f3e5e74Sdrh Expr *pExpr, 13305f3e5e74Sdrh u8 *pEstWidth 13315f3e5e74Sdrh ){ 13325f3e5e74Sdrh #endif /* !defined(SQLITE_ENABLE_COLUMN_METADATA) */ 1333955de52cSdanielk1977 char const *zType = 0; 1334517eb646Sdanielk1977 int j; 13355f3e5e74Sdrh u8 estWidth = 1; 13365338a5f7Sdanielk1977 13375f3e5e74Sdrh if( NEVER(pExpr==0) || pNC->pSrcList==0 ) return 0; 133800e279d9Sdanielk1977 switch( pExpr->op ){ 133930bcf5dbSdrh case TK_AGG_COLUMN: 134000e279d9Sdanielk1977 case TK_COLUMN: { 1341955de52cSdanielk1977 /* The expression is a column. Locate the table the column is being 1342955de52cSdanielk1977 ** extracted from in NameContext.pSrcList. This table may be real 1343955de52cSdanielk1977 ** database table or a subquery. 1344955de52cSdanielk1977 */ 1345955de52cSdanielk1977 Table *pTab = 0; /* Table structure column is extracted from */ 1346955de52cSdanielk1977 Select *pS = 0; /* Select the column is extracted from */ 1347955de52cSdanielk1977 int iCol = pExpr->iColumn; /* Index of column in pTab */ 1348373cc2ddSdrh testcase( pExpr->op==TK_AGG_COLUMN ); 1349373cc2ddSdrh testcase( pExpr->op==TK_COLUMN ); 135043bc88bbSdan while( pNC && !pTab ){ 1351b3bce662Sdanielk1977 SrcList *pTabList = pNC->pSrcList; 1352b3bce662Sdanielk1977 for(j=0;j<pTabList->nSrc && pTabList->a[j].iCursor!=pExpr->iTable;j++); 1353b3bce662Sdanielk1977 if( j<pTabList->nSrc ){ 13546a3ea0e6Sdrh pTab = pTabList->a[j].pTab; 1355955de52cSdanielk1977 pS = pTabList->a[j].pSelect; 1356b3bce662Sdanielk1977 }else{ 1357b3bce662Sdanielk1977 pNC = pNC->pNext; 1358b3bce662Sdanielk1977 } 1359b3bce662Sdanielk1977 } 1360955de52cSdanielk1977 136143bc88bbSdan if( pTab==0 ){ 1362417168adSdrh /* At one time, code such as "SELECT new.x" within a trigger would 1363417168adSdrh ** cause this condition to run. Since then, we have restructured how 1364417168adSdrh ** trigger code is generated and so this condition is no longer 136543bc88bbSdan ** possible. However, it can still be true for statements like 136643bc88bbSdan ** the following: 136743bc88bbSdan ** 136843bc88bbSdan ** CREATE TABLE t1(col INTEGER); 136943bc88bbSdan ** SELECT (SELECT t1.col) FROM FROM t1; 137043bc88bbSdan ** 137143bc88bbSdan ** when columnType() is called on the expression "t1.col" in the 137243bc88bbSdan ** sub-select. In this case, set the column type to NULL, even 137343bc88bbSdan ** though it should really be "INTEGER". 137443bc88bbSdan ** 137543bc88bbSdan ** This is not a problem, as the column type of "t1.col" is never 137643bc88bbSdan ** used. When columnType() is called on the expression 137743bc88bbSdan ** "(SELECT t1.col)", the correct type is returned (see the TK_SELECT 137843bc88bbSdan ** branch below. */ 13797e62779aSdrh break; 13807e62779aSdrh } 1381955de52cSdanielk1977 138243bc88bbSdan assert( pTab && pExpr->pTab==pTab ); 1383955de52cSdanielk1977 if( pS ){ 1384955de52cSdanielk1977 /* The "table" is actually a sub-select or a view in the FROM clause 1385955de52cSdanielk1977 ** of the SELECT statement. Return the declaration type and origin 1386955de52cSdanielk1977 ** data for the result-set column of the sub-select. 1387955de52cSdanielk1977 */ 13887b688edeSdrh if( iCol>=0 && ALWAYS(iCol<pS->pEList->nExpr) ){ 1389955de52cSdanielk1977 /* If iCol is less than zero, then the expression requests the 1390955de52cSdanielk1977 ** rowid of the sub-select or view. This expression is legal (see 1391955de52cSdanielk1977 ** test case misc2.2.2) - it always evaluates to NULL. 1392955de52cSdanielk1977 */ 1393955de52cSdanielk1977 NameContext sNC; 1394955de52cSdanielk1977 Expr *p = pS->pEList->a[iCol].pExpr; 1395955de52cSdanielk1977 sNC.pSrcList = pS->pSrc; 139643bc88bbSdan sNC.pNext = pNC; 1397955de52cSdanielk1977 sNC.pParse = pNC->pParse; 13985f3e5e74Sdrh zType = columnType(&sNC, p,&zOrigDb,&zOrigTab,&zOrigCol, &estWidth); 1399955de52cSdanielk1977 } 140093c36bb3Sdrh }else if( pTab->pSchema ){ 1401955de52cSdanielk1977 /* A real table */ 1402955de52cSdanielk1977 assert( !pS ); 1403fcb78a49Sdrh if( iCol<0 ) iCol = pTab->iPKey; 1404fcb78a49Sdrh assert( iCol==-1 || (iCol>=0 && iCol<pTab->nCol) ); 14055f3e5e74Sdrh #ifdef SQLITE_ENABLE_COLUMN_METADATA 1406fcb78a49Sdrh if( iCol<0 ){ 1407fcb78a49Sdrh zType = "INTEGER"; 14085f3e5e74Sdrh zOrigCol = "rowid"; 1409fcb78a49Sdrh }else{ 1410fcb78a49Sdrh zType = pTab->aCol[iCol].zType; 14115f3e5e74Sdrh zOrigCol = pTab->aCol[iCol].zName; 14125f3e5e74Sdrh estWidth = pTab->aCol[iCol].szEst; 1413955de52cSdanielk1977 } 14145f3e5e74Sdrh zOrigTab = pTab->zName; 1415955de52cSdanielk1977 if( pNC->pParse ){ 1416955de52cSdanielk1977 int iDb = sqlite3SchemaToIndex(pNC->pParse->db, pTab->pSchema); 14175f3e5e74Sdrh zOrigDb = pNC->pParse->db->aDb[iDb].zName; 1418955de52cSdanielk1977 } 14195f3e5e74Sdrh #else 14205f3e5e74Sdrh if( iCol<0 ){ 14215f3e5e74Sdrh zType = "INTEGER"; 14225f3e5e74Sdrh }else{ 14235f3e5e74Sdrh zType = pTab->aCol[iCol].zType; 14245f3e5e74Sdrh estWidth = pTab->aCol[iCol].szEst; 14255f3e5e74Sdrh } 14265f3e5e74Sdrh #endif 1427fcb78a49Sdrh } 142800e279d9Sdanielk1977 break; 1429736c22b8Sdrh } 143093758c8dSdanielk1977 #ifndef SQLITE_OMIT_SUBQUERY 143100e279d9Sdanielk1977 case TK_SELECT: { 1432955de52cSdanielk1977 /* The expression is a sub-select. Return the declaration type and 1433955de52cSdanielk1977 ** origin info for the single column in the result set of the SELECT 1434955de52cSdanielk1977 ** statement. 1435955de52cSdanielk1977 */ 1436b3bce662Sdanielk1977 NameContext sNC; 14376ab3a2ecSdanielk1977 Select *pS = pExpr->x.pSelect; 1438955de52cSdanielk1977 Expr *p = pS->pEList->a[0].pExpr; 14396ab3a2ecSdanielk1977 assert( ExprHasProperty(pExpr, EP_xIsSelect) ); 1440955de52cSdanielk1977 sNC.pSrcList = pS->pSrc; 1441b3bce662Sdanielk1977 sNC.pNext = pNC; 1442955de52cSdanielk1977 sNC.pParse = pNC->pParse; 14435f3e5e74Sdrh zType = columnType(&sNC, p, &zOrigDb, &zOrigTab, &zOrigCol, &estWidth); 144400e279d9Sdanielk1977 break; 1445fcb78a49Sdrh } 144693758c8dSdanielk1977 #endif 144700e279d9Sdanielk1977 } 144800e279d9Sdanielk1977 14495f3e5e74Sdrh #ifdef SQLITE_ENABLE_COLUMN_METADATA 14505f3e5e74Sdrh if( pzOrigDb ){ 14515f3e5e74Sdrh assert( pzOrigTab && pzOrigCol ); 14525f3e5e74Sdrh *pzOrigDb = zOrigDb; 14535f3e5e74Sdrh *pzOrigTab = zOrigTab; 14545f3e5e74Sdrh *pzOrigCol = zOrigCol; 1455955de52cSdanielk1977 } 14565f3e5e74Sdrh #endif 14575f3e5e74Sdrh if( pEstWidth ) *pEstWidth = estWidth; 1458517eb646Sdanielk1977 return zType; 1459517eb646Sdanielk1977 } 1460517eb646Sdanielk1977 1461517eb646Sdanielk1977 /* 1462517eb646Sdanielk1977 ** Generate code that will tell the VDBE the declaration types of columns 1463517eb646Sdanielk1977 ** in the result set. 1464517eb646Sdanielk1977 */ 1465517eb646Sdanielk1977 static void generateColumnTypes( 1466517eb646Sdanielk1977 Parse *pParse, /* Parser context */ 1467517eb646Sdanielk1977 SrcList *pTabList, /* List of tables */ 1468517eb646Sdanielk1977 ExprList *pEList /* Expressions defining the result set */ 1469517eb646Sdanielk1977 ){ 14703f913576Sdrh #ifndef SQLITE_OMIT_DECLTYPE 1471517eb646Sdanielk1977 Vdbe *v = pParse->pVdbe; 1472517eb646Sdanielk1977 int i; 1473b3bce662Sdanielk1977 NameContext sNC; 1474b3bce662Sdanielk1977 sNC.pSrcList = pTabList; 1475955de52cSdanielk1977 sNC.pParse = pParse; 1476517eb646Sdanielk1977 for(i=0; i<pEList->nExpr; i++){ 1477517eb646Sdanielk1977 Expr *p = pEList->a[i].pExpr; 14783f913576Sdrh const char *zType; 14793f913576Sdrh #ifdef SQLITE_ENABLE_COLUMN_METADATA 1480955de52cSdanielk1977 const char *zOrigDb = 0; 1481955de52cSdanielk1977 const char *zOrigTab = 0; 1482955de52cSdanielk1977 const char *zOrigCol = 0; 14835f3e5e74Sdrh zType = columnType(&sNC, p, &zOrigDb, &zOrigTab, &zOrigCol, 0); 1484955de52cSdanielk1977 148585b623f2Sdrh /* The vdbe must make its own copy of the column-type and other 14864b1ae99dSdanielk1977 ** column specific strings, in case the schema is reset before this 14874b1ae99dSdanielk1977 ** virtual machine is deleted. 1488fbcd585fSdanielk1977 */ 148910fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_DATABASE, zOrigDb, SQLITE_TRANSIENT); 149010fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_TABLE, zOrigTab, SQLITE_TRANSIENT); 149110fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_COLUMN, zOrigCol, SQLITE_TRANSIENT); 14923f913576Sdrh #else 14935f3e5e74Sdrh zType = columnType(&sNC, p, 0, 0, 0, 0); 14943f913576Sdrh #endif 149510fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_DECLTYPE, zType, SQLITE_TRANSIENT); 1496fcb78a49Sdrh } 14975f3e5e74Sdrh #endif /* !defined(SQLITE_OMIT_DECLTYPE) */ 1498fcb78a49Sdrh } 1499fcb78a49Sdrh 1500fcb78a49Sdrh /* 1501fcb78a49Sdrh ** Generate code that will tell the VDBE the names of columns 1502fcb78a49Sdrh ** in the result set. This information is used to provide the 1503fcabd464Sdrh ** azCol[] values in the callback. 150482c3d636Sdrh */ 1505832508b7Sdrh static void generateColumnNames( 1506832508b7Sdrh Parse *pParse, /* Parser context */ 1507ad3cab52Sdrh SrcList *pTabList, /* List of tables */ 1508832508b7Sdrh ExprList *pEList /* Expressions defining the result set */ 1509832508b7Sdrh ){ 1510d8bc7086Sdrh Vdbe *v = pParse->pVdbe; 15116a3ea0e6Sdrh int i, j; 15129bb575fdSdrh sqlite3 *db = pParse->db; 1513fcabd464Sdrh int fullNames, shortNames; 1514fcabd464Sdrh 1515fe2093d7Sdrh #ifndef SQLITE_OMIT_EXPLAIN 15163cf86063Sdanielk1977 /* If this is an EXPLAIN, skip this step */ 15173cf86063Sdanielk1977 if( pParse->explain ){ 151861de0d1bSdanielk1977 return; 15193cf86063Sdanielk1977 } 15205338a5f7Sdanielk1977 #endif 15213cf86063Sdanielk1977 1522e2f02bacSdrh if( pParse->colNamesSet || NEVER(v==0) || db->mallocFailed ) return; 1523d8bc7086Sdrh pParse->colNamesSet = 1; 1524fcabd464Sdrh fullNames = (db->flags & SQLITE_FullColNames)!=0; 1525fcabd464Sdrh shortNames = (db->flags & SQLITE_ShortColNames)!=0; 152622322fd4Sdanielk1977 sqlite3VdbeSetNumCols(v, pEList->nExpr); 152782c3d636Sdrh for(i=0; i<pEList->nExpr; i++){ 152882c3d636Sdrh Expr *p; 15295a38705eSdrh p = pEList->a[i].pExpr; 1530373cc2ddSdrh if( NEVER(p==0) ) continue; 153182c3d636Sdrh if( pEList->a[i].zName ){ 153282c3d636Sdrh char *zName = pEList->a[i].zName; 153310fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_NAME, zName, SQLITE_TRANSIENT); 1534f018cc2eSdrh }else if( (p->op==TK_COLUMN || p->op==TK_AGG_COLUMN) && pTabList ){ 15356a3ea0e6Sdrh Table *pTab; 153697665873Sdrh char *zCol; 15378aff1015Sdrh int iCol = p->iColumn; 1538e2f02bacSdrh for(j=0; ALWAYS(j<pTabList->nSrc); j++){ 1539e2f02bacSdrh if( pTabList->a[j].iCursor==p->iTable ) break; 1540e2f02bacSdrh } 15416a3ea0e6Sdrh assert( j<pTabList->nSrc ); 15426a3ea0e6Sdrh pTab = pTabList->a[j].pTab; 15438aff1015Sdrh if( iCol<0 ) iCol = pTab->iPKey; 154497665873Sdrh assert( iCol==-1 || (iCol>=0 && iCol<pTab->nCol) ); 1545b1363206Sdrh if( iCol<0 ){ 154647a6db2bSdrh zCol = "rowid"; 1547b1363206Sdrh }else{ 1548b1363206Sdrh zCol = pTab->aCol[iCol].zName; 1549b1363206Sdrh } 1550e49b146fSdrh if( !shortNames && !fullNames ){ 155110fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_NAME, 1552b7916a78Sdrh sqlite3DbStrDup(db, pEList->a[i].zSpan), SQLITE_DYNAMIC); 15531c767f0dSdrh }else if( fullNames ){ 155482c3d636Sdrh char *zName = 0; 15551c767f0dSdrh zName = sqlite3MPrintf(db, "%s.%s", pTab->zName, zCol); 155610fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_NAME, zName, SQLITE_DYNAMIC); 155782c3d636Sdrh }else{ 155810fb749bSdanielk1977 sqlite3VdbeSetColName(v, i, COLNAME_NAME, zCol, SQLITE_TRANSIENT); 155982c3d636Sdrh } 15601bee3d7bSdrh }else{ 1561859bc542Sdrh const char *z = pEList->a[i].zSpan; 1562859bc542Sdrh z = z==0 ? sqlite3MPrintf(db, "column%d", i+1) : sqlite3DbStrDup(db, z); 1563859bc542Sdrh sqlite3VdbeSetColName(v, i, COLNAME_NAME, z, SQLITE_DYNAMIC); 156482c3d636Sdrh } 156582c3d636Sdrh } 156676d505baSdanielk1977 generateColumnTypes(pParse, pTabList, pEList); 15675080aaa7Sdrh } 156882c3d636Sdrh 1569d8bc7086Sdrh /* 157060ec914cSpeter.d.reid ** Given an expression list (which is really the list of expressions 15717d10d5a6Sdrh ** that form the result set of a SELECT statement) compute appropriate 15727d10d5a6Sdrh ** column names for a table that would hold the expression list. 15737d10d5a6Sdrh ** 15747d10d5a6Sdrh ** All column names will be unique. 15757d10d5a6Sdrh ** 15767d10d5a6Sdrh ** Only the column names are computed. Column.zType, Column.zColl, 15777d10d5a6Sdrh ** and other fields of Column are zeroed. 15787d10d5a6Sdrh ** 15797d10d5a6Sdrh ** Return SQLITE_OK on success. If a memory allocation error occurs, 15807d10d5a6Sdrh ** store NULL in *paCol and 0 in *pnCol and return SQLITE_NOMEM. 1581315555caSdrh */ 15827d10d5a6Sdrh static int selectColumnsFromExprList( 15837d10d5a6Sdrh Parse *pParse, /* Parsing context */ 15847d10d5a6Sdrh ExprList *pEList, /* Expr list from which to derive column names */ 1585d815f17dSdrh i16 *pnCol, /* Write the number of columns here */ 15867d10d5a6Sdrh Column **paCol /* Write the new column list here */ 15877d10d5a6Sdrh ){ 1588dc5ea5c7Sdrh sqlite3 *db = pParse->db; /* Database connection */ 1589dc5ea5c7Sdrh int i, j; /* Loop counters */ 1590dc5ea5c7Sdrh int cnt; /* Index added to make the name unique */ 1591dc5ea5c7Sdrh Column *aCol, *pCol; /* For looping over result columns */ 1592dc5ea5c7Sdrh int nCol; /* Number of columns in the result set */ 1593dc5ea5c7Sdrh Expr *p; /* Expression for a single result column */ 1594dc5ea5c7Sdrh char *zName; /* Column name */ 1595dc5ea5c7Sdrh int nName; /* Size of name in zName[] */ 159679d5f63fSdrh 15978c2e0f02Sdan if( pEList ){ 15988c2e0f02Sdan nCol = pEList->nExpr; 15998c2e0f02Sdan aCol = sqlite3DbMallocZero(db, sizeof(aCol[0])*nCol); 16008c2e0f02Sdan testcase( aCol==0 ); 16018c2e0f02Sdan }else{ 16028c2e0f02Sdan nCol = 0; 16038c2e0f02Sdan aCol = 0; 16048c2e0f02Sdan } 16058c2e0f02Sdan *pnCol = nCol; 16068c2e0f02Sdan *paCol = aCol; 16078c2e0f02Sdan 16087d10d5a6Sdrh for(i=0, pCol=aCol; i<nCol; i++, pCol++){ 160979d5f63fSdrh /* Get an appropriate name for the column 161079d5f63fSdrh */ 1611580c8c18Sdrh p = sqlite3ExprSkipCollate(pEList->a[i].pExpr); 161291bb0eedSdrh if( (zName = pEList->a[i].zName)!=0 ){ 161379d5f63fSdrh /* If the column contains an "AS <name>" phrase, use <name> as the name */ 161417435752Sdrh zName = sqlite3DbStrDup(db, zName); 16157d10d5a6Sdrh }else{ 1616dc5ea5c7Sdrh Expr *pColExpr = p; /* The expression that is the result column name */ 1617dc5ea5c7Sdrh Table *pTab; /* Table associated with this expression */ 1618b07028f7Sdrh while( pColExpr->op==TK_DOT ){ 1619b07028f7Sdrh pColExpr = pColExpr->pRight; 1620b07028f7Sdrh assert( pColExpr!=0 ); 1621b07028f7Sdrh } 1622373cc2ddSdrh if( pColExpr->op==TK_COLUMN && ALWAYS(pColExpr->pTab!=0) ){ 162393a960a0Sdrh /* For columns use the column name name */ 1624dc5ea5c7Sdrh int iCol = pColExpr->iColumn; 1625373cc2ddSdrh pTab = pColExpr->pTab; 1626f0209f74Sdrh if( iCol<0 ) iCol = pTab->iPKey; 1627f0209f74Sdrh zName = sqlite3MPrintf(db, "%s", 1628f0209f74Sdrh iCol>=0 ? pTab->aCol[iCol].zName : "rowid"); 1629b7916a78Sdrh }else if( pColExpr->op==TK_ID ){ 163033e619fcSdrh assert( !ExprHasProperty(pColExpr, EP_IntValue) ); 163133e619fcSdrh zName = sqlite3MPrintf(db, "%s", pColExpr->u.zToken); 163293a960a0Sdrh }else{ 163379d5f63fSdrh /* Use the original text of the column expression as its name */ 1634b7916a78Sdrh zName = sqlite3MPrintf(db, "%s", pEList->a[i].zSpan); 16357d10d5a6Sdrh } 163622f70c32Sdrh } 16377ce72f69Sdrh if( db->mallocFailed ){ 1638633e6d57Sdrh sqlite3DbFree(db, zName); 16397ce72f69Sdrh break; 1640dd5b2fa5Sdrh } 164179d5f63fSdrh 164279d5f63fSdrh /* Make sure the column name is unique. If the name is not unique, 164360ec914cSpeter.d.reid ** append an integer to the name so that it becomes unique. 164479d5f63fSdrh */ 1645ea678832Sdrh nName = sqlite3Strlen30(zName); 164679d5f63fSdrh for(j=cnt=0; j<i; j++){ 164779d5f63fSdrh if( sqlite3StrICmp(aCol[j].zName, zName)==0 ){ 1648633e6d57Sdrh char *zNewName; 1649fb777327Sdrh int k; 1650fb777327Sdrh for(k=nName-1; k>1 && sqlite3Isdigit(zName[k]); k--){} 165119c6d96aSdrh if( k>=0 && zName[k]==':' ) nName = k; 16522564ef97Sdrh zName[nName] = 0; 1653633e6d57Sdrh zNewName = sqlite3MPrintf(db, "%s:%d", zName, ++cnt); 1654633e6d57Sdrh sqlite3DbFree(db, zName); 1655633e6d57Sdrh zName = zNewName; 165679d5f63fSdrh j = -1; 1657dd5b2fa5Sdrh if( zName==0 ) break; 165879d5f63fSdrh } 165979d5f63fSdrh } 166091bb0eedSdrh pCol->zName = zName; 16617d10d5a6Sdrh } 16627d10d5a6Sdrh if( db->mallocFailed ){ 16637d10d5a6Sdrh for(j=0; j<i; j++){ 16647d10d5a6Sdrh sqlite3DbFree(db, aCol[j].zName); 16657d10d5a6Sdrh } 16667d10d5a6Sdrh sqlite3DbFree(db, aCol); 16677d10d5a6Sdrh *paCol = 0; 16687d10d5a6Sdrh *pnCol = 0; 16697d10d5a6Sdrh return SQLITE_NOMEM; 16707d10d5a6Sdrh } 16717d10d5a6Sdrh return SQLITE_OK; 16727d10d5a6Sdrh } 1673e014a838Sdanielk1977 16747d10d5a6Sdrh /* 16757d10d5a6Sdrh ** Add type and collation information to a column list based on 16767d10d5a6Sdrh ** a SELECT statement. 16777d10d5a6Sdrh ** 16787d10d5a6Sdrh ** The column list presumably came from selectColumnNamesFromExprList(). 16797d10d5a6Sdrh ** The column list has only names, not types or collations. This 16807d10d5a6Sdrh ** routine goes through and adds the types and collations. 16817d10d5a6Sdrh ** 1682b08a67a7Sshane ** This routine requires that all identifiers in the SELECT 16837d10d5a6Sdrh ** statement be resolved. 168479d5f63fSdrh */ 16857d10d5a6Sdrh static void selectAddColumnTypeAndCollation( 16867d10d5a6Sdrh Parse *pParse, /* Parsing contexts */ 1687186ad8ccSdrh Table *pTab, /* Add column type information to this table */ 16887d10d5a6Sdrh Select *pSelect /* SELECT used to determine types and collations */ 16897d10d5a6Sdrh ){ 16907d10d5a6Sdrh sqlite3 *db = pParse->db; 16917d10d5a6Sdrh NameContext sNC; 16927d10d5a6Sdrh Column *pCol; 16937d10d5a6Sdrh CollSeq *pColl; 16947d10d5a6Sdrh int i; 16957d10d5a6Sdrh Expr *p; 16967d10d5a6Sdrh struct ExprList_item *a; 1697186ad8ccSdrh u64 szAll = 0; 16987d10d5a6Sdrh 16997d10d5a6Sdrh assert( pSelect!=0 ); 17007d10d5a6Sdrh assert( (pSelect->selFlags & SF_Resolved)!=0 ); 1701186ad8ccSdrh assert( pTab->nCol==pSelect->pEList->nExpr || db->mallocFailed ); 17027d10d5a6Sdrh if( db->mallocFailed ) return; 1703c43e8be8Sdrh memset(&sNC, 0, sizeof(sNC)); 1704b3bce662Sdanielk1977 sNC.pSrcList = pSelect->pSrc; 17057d10d5a6Sdrh a = pSelect->pEList->a; 1706186ad8ccSdrh for(i=0, pCol=pTab->aCol; i<pTab->nCol; i++, pCol++){ 17077d10d5a6Sdrh p = a[i].pExpr; 17085f3e5e74Sdrh pCol->zType = sqlite3DbStrDup(db, columnType(&sNC, p,0,0,0, &pCol->szEst)); 1709186ad8ccSdrh szAll += pCol->szEst; 1710c60e9b82Sdanielk1977 pCol->affinity = sqlite3ExprAffinity(p); 1711c4a64facSdrh if( pCol->affinity==0 ) pCol->affinity = SQLITE_AFF_NONE; 1712b3bf556eSdanielk1977 pColl = sqlite3ExprCollSeq(pParse, p); 1713b3bf556eSdanielk1977 if( pColl ){ 171417435752Sdrh pCol->zColl = sqlite3DbStrDup(db, pColl->zName); 17150202b29eSdanielk1977 } 171622f70c32Sdrh } 1717186ad8ccSdrh pTab->szTabRow = sqlite3LogEst(szAll*4); 17187d10d5a6Sdrh } 17197d10d5a6Sdrh 17207d10d5a6Sdrh /* 17217d10d5a6Sdrh ** Given a SELECT statement, generate a Table structure that describes 17227d10d5a6Sdrh ** the result set of that SELECT. 17237d10d5a6Sdrh */ 17247d10d5a6Sdrh Table *sqlite3ResultSetOfSelect(Parse *pParse, Select *pSelect){ 17257d10d5a6Sdrh Table *pTab; 17267d10d5a6Sdrh sqlite3 *db = pParse->db; 17277d10d5a6Sdrh int savedFlags; 17287d10d5a6Sdrh 17297d10d5a6Sdrh savedFlags = db->flags; 17307d10d5a6Sdrh db->flags &= ~SQLITE_FullColNames; 17317d10d5a6Sdrh db->flags |= SQLITE_ShortColNames; 17327d10d5a6Sdrh sqlite3SelectPrep(pParse, pSelect, 0); 17337d10d5a6Sdrh if( pParse->nErr ) return 0; 17347d10d5a6Sdrh while( pSelect->pPrior ) pSelect = pSelect->pPrior; 17357d10d5a6Sdrh db->flags = savedFlags; 17367d10d5a6Sdrh pTab = sqlite3DbMallocZero(db, sizeof(Table) ); 17377d10d5a6Sdrh if( pTab==0 ){ 17387d10d5a6Sdrh return 0; 17397d10d5a6Sdrh } 1740373cc2ddSdrh /* The sqlite3ResultSetOfSelect() is only used n contexts where lookaside 1741b2468954Sdrh ** is disabled */ 1742373cc2ddSdrh assert( db->lookaside.bEnabled==0 ); 17437d10d5a6Sdrh pTab->nRef = 1; 17447d10d5a6Sdrh pTab->zName = 0; 1745cfc9df76Sdan pTab->nRowLogEst = 200; assert( 200==sqlite3LogEst(1048576) ); 17467d10d5a6Sdrh selectColumnsFromExprList(pParse, pSelect->pEList, &pTab->nCol, &pTab->aCol); 1747186ad8ccSdrh selectAddColumnTypeAndCollation(pParse, pTab, pSelect); 174822f70c32Sdrh pTab->iPKey = -1; 17497ce72f69Sdrh if( db->mallocFailed ){ 17501feeaed2Sdan sqlite3DeleteTable(db, pTab); 17517ce72f69Sdrh return 0; 17527ce72f69Sdrh } 175322f70c32Sdrh return pTab; 175422f70c32Sdrh } 175522f70c32Sdrh 175622f70c32Sdrh /* 1757d8bc7086Sdrh ** Get a VDBE for the given parser context. Create a new one if necessary. 1758d8bc7086Sdrh ** If an error occurs, return NULL and leave a message in pParse. 1759d8bc7086Sdrh */ 17604adee20fSdanielk1977 Vdbe *sqlite3GetVdbe(Parse *pParse){ 1761d8bc7086Sdrh Vdbe *v = pParse->pVdbe; 1762d8bc7086Sdrh if( v==0 ){ 17639ac7962aSdrh v = pParse->pVdbe = sqlite3VdbeCreate(pParse); 1764aceb31b1Sdrh if( v ) sqlite3VdbeAddOp0(v, OP_Init); 1765e0e261a4Sdrh if( pParse->pToplevel==0 1766e0e261a4Sdrh && OptimizationEnabled(pParse->db,SQLITE_FactorOutConst) 1767e0e261a4Sdrh ){ 1768e0e261a4Sdrh pParse->okConstFactor = 1; 1769e0e261a4Sdrh } 1770e0e261a4Sdrh 1771d8bc7086Sdrh } 1772d8bc7086Sdrh return v; 1773d8bc7086Sdrh } 1774d8bc7086Sdrh 177515007a99Sdrh 1776d8bc7086Sdrh /* 17777b58daeaSdrh ** Compute the iLimit and iOffset fields of the SELECT based on the 1778ec7429aeSdrh ** pLimit and pOffset expressions. pLimit and pOffset hold the expressions 17797b58daeaSdrh ** that appear in the original SQL statement after the LIMIT and OFFSET 1780a2dc3b1aSdanielk1977 ** keywords. Or NULL if those keywords are omitted. iLimit and iOffset 1781a2dc3b1aSdanielk1977 ** are the integer memory register numbers for counters used to compute 1782a2dc3b1aSdanielk1977 ** the limit and offset. If there is no limit and/or offset, then 1783a2dc3b1aSdanielk1977 ** iLimit and iOffset are negative. 17847b58daeaSdrh ** 1785d59ba6ceSdrh ** This routine changes the values of iLimit and iOffset only if 1786ec7429aeSdrh ** a limit or offset is defined by pLimit and pOffset. iLimit and 1787aa9ce707Sdrh ** iOffset should have been preset to appropriate default values (zero) 1788aa9ce707Sdrh ** prior to calling this routine. 1789aa9ce707Sdrh ** 1790aa9ce707Sdrh ** The iOffset register (if it exists) is initialized to the value 1791aa9ce707Sdrh ** of the OFFSET. The iLimit register is initialized to LIMIT. Register 1792aa9ce707Sdrh ** iOffset+1 is initialized to LIMIT+OFFSET. 1793aa9ce707Sdrh ** 1794ec7429aeSdrh ** Only if pLimit!=0 or pOffset!=0 do the limit registers get 17957b58daeaSdrh ** redefined. The UNION ALL operator uses this property to force 17967b58daeaSdrh ** the reuse of the same limit and offset registers across multiple 17977b58daeaSdrh ** SELECT statements. 17987b58daeaSdrh */ 1799ec7429aeSdrh static void computeLimitRegisters(Parse *pParse, Select *p, int iBreak){ 180002afc861Sdrh Vdbe *v = 0; 180102afc861Sdrh int iLimit = 0; 180215007a99Sdrh int iOffset; 18039b918ed1Sdrh int addr1, n; 18040acb7e48Sdrh if( p->iLimit ) return; 180515007a99Sdrh 18067b58daeaSdrh /* 18077b58daeaSdrh ** "LIMIT -1" always shows all rows. There is some 1808f7b5496eSdrh ** controversy about what the correct behavior should be. 18097b58daeaSdrh ** The current implementation interprets "LIMIT 0" to mean 18107b58daeaSdrh ** no rows. 18117b58daeaSdrh */ 1812ceea3321Sdrh sqlite3ExprCacheClear(pParse); 1813373cc2ddSdrh assert( p->pOffset==0 || p->pLimit!=0 ); 1814a2dc3b1aSdanielk1977 if( p->pLimit ){ 18150a07c107Sdrh p->iLimit = iLimit = ++pParse->nMem; 181615007a99Sdrh v = sqlite3GetVdbe(pParse); 1817aa9ce707Sdrh assert( v!=0 ); 18189b918ed1Sdrh if( sqlite3ExprIsInteger(p->pLimit, &n) ){ 18199b918ed1Sdrh sqlite3VdbeAddOp2(v, OP_Integer, n, iLimit); 18209b918ed1Sdrh VdbeComment((v, "LIMIT counter")); 1821456e4e4fSdrh if( n==0 ){ 1822456e4e4fSdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, iBreak); 1823613ba1eaSdrh }else if( n>=0 && p->nSelectRow>(u64)n ){ 1824613ba1eaSdrh p->nSelectRow = n; 18259b918ed1Sdrh } 18269b918ed1Sdrh }else{ 1827b7654111Sdrh sqlite3ExprCode(pParse, p->pLimit, iLimit); 1828688852abSdrh sqlite3VdbeAddOp1(v, OP_MustBeInt, iLimit); VdbeCoverage(v); 1829d4e70ebdSdrh VdbeComment((v, "LIMIT counter")); 1830688852abSdrh sqlite3VdbeAddOp2(v, OP_IfZero, iLimit, iBreak); VdbeCoverage(v); 18319b918ed1Sdrh } 1832a2dc3b1aSdanielk1977 if( p->pOffset ){ 18330a07c107Sdrh p->iOffset = iOffset = ++pParse->nMem; 1834b7654111Sdrh pParse->nMem++; /* Allocate an extra register for limit+offset */ 1835b7654111Sdrh sqlite3ExprCode(pParse, p->pOffset, iOffset); 1836688852abSdrh sqlite3VdbeAddOp1(v, OP_MustBeInt, iOffset); VdbeCoverage(v); 1837d4e70ebdSdrh VdbeComment((v, "OFFSET counter")); 1838688852abSdrh addr1 = sqlite3VdbeAddOp1(v, OP_IfPos, iOffset); VdbeCoverage(v); 1839b7654111Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 0, iOffset); 184015007a99Sdrh sqlite3VdbeJumpHere(v, addr1); 1841b7654111Sdrh sqlite3VdbeAddOp3(v, OP_Add, iLimit, iOffset, iOffset+1); 1842d4e70ebdSdrh VdbeComment((v, "LIMIT+OFFSET")); 1843688852abSdrh addr1 = sqlite3VdbeAddOp1(v, OP_IfPos, iLimit); VdbeCoverage(v); 1844b7654111Sdrh sqlite3VdbeAddOp2(v, OP_Integer, -1, iOffset+1); 1845b7654111Sdrh sqlite3VdbeJumpHere(v, addr1); 1846b7654111Sdrh } 1847d59ba6ceSdrh } 18487b58daeaSdrh } 18497b58daeaSdrh 1850b7f9164eSdrh #ifndef SQLITE_OMIT_COMPOUND_SELECT 1851fbc4ee7bSdrh /* 1852fbc4ee7bSdrh ** Return the appropriate collating sequence for the iCol-th column of 1853fbc4ee7bSdrh ** the result set for the compound-select statement "p". Return NULL if 1854fbc4ee7bSdrh ** the column has no default collating sequence. 1855fbc4ee7bSdrh ** 1856fbc4ee7bSdrh ** The collating sequence for the compound select is taken from the 1857fbc4ee7bSdrh ** left-most term of the select that has a collating sequence. 1858fbc4ee7bSdrh */ 1859dc1bdc4fSdanielk1977 static CollSeq *multiSelectCollSeq(Parse *pParse, Select *p, int iCol){ 1860fbc4ee7bSdrh CollSeq *pRet; 1861dc1bdc4fSdanielk1977 if( p->pPrior ){ 1862dc1bdc4fSdanielk1977 pRet = multiSelectCollSeq(pParse, p->pPrior, iCol); 1863fbc4ee7bSdrh }else{ 1864fbc4ee7bSdrh pRet = 0; 1865dc1bdc4fSdanielk1977 } 186610c081adSdrh assert( iCol>=0 ); 186710c081adSdrh if( pRet==0 && iCol<p->pEList->nExpr ){ 1868dc1bdc4fSdanielk1977 pRet = sqlite3ExprCollSeq(pParse, p->pEList->a[iCol].pExpr); 1869dc1bdc4fSdanielk1977 } 1870dc1bdc4fSdanielk1977 return pRet; 1871d3d39e93Sdrh } 187253bed45eSdan 187353bed45eSdan /* 187453bed45eSdan ** The select statement passed as the second parameter is a compound SELECT 187553bed45eSdan ** with an ORDER BY clause. This function allocates and returns a KeyInfo 187653bed45eSdan ** structure suitable for implementing the ORDER BY. 187753bed45eSdan ** 187853bed45eSdan ** Space to hold the KeyInfo structure is obtained from malloc. The calling 187953bed45eSdan ** function is responsible for ensuring that this structure is eventually 188053bed45eSdan ** freed. 188153bed45eSdan */ 188253bed45eSdan static KeyInfo *multiSelectOrderByKeyInfo(Parse *pParse, Select *p, int nExtra){ 188353bed45eSdan ExprList *pOrderBy = p->pOrderBy; 188453bed45eSdan int nOrderBy = p->pOrderBy->nExpr; 188553bed45eSdan sqlite3 *db = pParse->db; 188653bed45eSdan KeyInfo *pRet = sqlite3KeyInfoAlloc(db, nOrderBy+nExtra, 1); 188753bed45eSdan if( pRet ){ 188853bed45eSdan int i; 188953bed45eSdan for(i=0; i<nOrderBy; i++){ 189053bed45eSdan struct ExprList_item *pItem = &pOrderBy->a[i]; 189153bed45eSdan Expr *pTerm = pItem->pExpr; 189253bed45eSdan CollSeq *pColl; 189353bed45eSdan 189453bed45eSdan if( pTerm->flags & EP_Collate ){ 189553bed45eSdan pColl = sqlite3ExprCollSeq(pParse, pTerm); 189653bed45eSdan }else{ 189753bed45eSdan pColl = multiSelectCollSeq(pParse, p, pItem->u.x.iOrderByCol-1); 189853bed45eSdan if( pColl==0 ) pColl = db->pDfltColl; 189953bed45eSdan pOrderBy->a[i].pExpr = 190053bed45eSdan sqlite3ExprAddCollateString(pParse, pTerm, pColl->zName); 190153bed45eSdan } 190253bed45eSdan assert( sqlite3KeyInfoIsWriteable(pRet) ); 190353bed45eSdan pRet->aColl[i] = pColl; 190453bed45eSdan pRet->aSortOrder[i] = pOrderBy->a[i].sortOrder; 190553bed45eSdan } 190653bed45eSdan } 190753bed45eSdan 190853bed45eSdan return pRet; 190953bed45eSdan } 1910d3d39e93Sdrh 1911781def29Sdrh #ifndef SQLITE_OMIT_CTE 1912781def29Sdrh /* 1913781def29Sdrh ** This routine generates VDBE code to compute the content of a WITH RECURSIVE 1914781def29Sdrh ** query of the form: 1915781def29Sdrh ** 1916781def29Sdrh ** <recursive-table> AS (<setup-query> UNION [ALL] <recursive-query>) 1917781def29Sdrh ** \___________/ \_______________/ 1918781def29Sdrh ** p->pPrior p 1919781def29Sdrh ** 1920781def29Sdrh ** 1921781def29Sdrh ** There is exactly one reference to the recursive-table in the FROM clause 1922781def29Sdrh ** of recursive-query, marked with the SrcList->a[].isRecursive flag. 1923781def29Sdrh ** 1924781def29Sdrh ** The setup-query runs once to generate an initial set of rows that go 1925781def29Sdrh ** into a Queue table. Rows are extracted from the Queue table one by 1926fe1c6bb9Sdrh ** one. Each row extracted from Queue is output to pDest. Then the single 1927fe1c6bb9Sdrh ** extracted row (now in the iCurrent table) becomes the content of the 1928fe1c6bb9Sdrh ** recursive-table for a recursive-query run. The output of the recursive-query 1929781def29Sdrh ** is added back into the Queue table. Then another row is extracted from Queue 1930781def29Sdrh ** and the iteration continues until the Queue table is empty. 1931781def29Sdrh ** 1932781def29Sdrh ** If the compound query operator is UNION then no duplicate rows are ever 1933781def29Sdrh ** inserted into the Queue table. The iDistinct table keeps a copy of all rows 1934781def29Sdrh ** that have ever been inserted into Queue and causes duplicates to be 1935781def29Sdrh ** discarded. If the operator is UNION ALL, then duplicates are allowed. 1936781def29Sdrh ** 1937781def29Sdrh ** If the query has an ORDER BY, then entries in the Queue table are kept in 1938781def29Sdrh ** ORDER BY order and the first entry is extracted for each cycle. Without 1939781def29Sdrh ** an ORDER BY, the Queue table is just a FIFO. 1940781def29Sdrh ** 1941781def29Sdrh ** If a LIMIT clause is provided, then the iteration stops after LIMIT rows 1942781def29Sdrh ** have been output to pDest. A LIMIT of zero means to output no rows and a 1943781def29Sdrh ** negative LIMIT means to output all rows. If there is also an OFFSET clause 1944781def29Sdrh ** with a positive value, then the first OFFSET outputs are discarded rather 1945781def29Sdrh ** than being sent to pDest. The LIMIT count does not begin until after OFFSET 1946781def29Sdrh ** rows have been skipped. 1947781def29Sdrh */ 1948781def29Sdrh static void generateWithRecursiveQuery( 1949781def29Sdrh Parse *pParse, /* Parsing context */ 1950781def29Sdrh Select *p, /* The recursive SELECT to be coded */ 1951781def29Sdrh SelectDest *pDest /* What to do with query results */ 1952781def29Sdrh ){ 1953781def29Sdrh SrcList *pSrc = p->pSrc; /* The FROM clause of the recursive query */ 1954781def29Sdrh int nCol = p->pEList->nExpr; /* Number of columns in the recursive table */ 1955781def29Sdrh Vdbe *v = pParse->pVdbe; /* The prepared statement under construction */ 1956781def29Sdrh Select *pSetup = p->pPrior; /* The setup query */ 1957781def29Sdrh int addrTop; /* Top of the loop */ 1958781def29Sdrh int addrCont, addrBreak; /* CONTINUE and BREAK addresses */ 1959edf83d1eSdrh int iCurrent = 0; /* The Current table */ 1960781def29Sdrh int regCurrent; /* Register holding Current table */ 1961781def29Sdrh int iQueue; /* The Queue table */ 1962781def29Sdrh int iDistinct = 0; /* To ensure unique results if UNION */ 19638e1ee88cSdrh int eDest = SRT_Fifo; /* How to write to Queue */ 1964781def29Sdrh SelectDest destQueue; /* SelectDest targetting the Queue table */ 1965781def29Sdrh int i; /* Loop counter */ 1966781def29Sdrh int rc; /* Result code */ 1967fe1c6bb9Sdrh ExprList *pOrderBy; /* The ORDER BY clause */ 1968aa9ce707Sdrh Expr *pLimit, *pOffset; /* Saved LIMIT and OFFSET */ 1969aa9ce707Sdrh int regLimit, regOffset; /* Registers used by LIMIT and OFFSET */ 1970781def29Sdrh 1971781def29Sdrh /* Obtain authorization to do a recursive query */ 1972781def29Sdrh if( sqlite3AuthCheck(pParse, SQLITE_RECURSIVE, 0, 0, 0) ) return; 1973781def29Sdrh 1974aa9ce707Sdrh /* Process the LIMIT and OFFSET clauses, if they exist */ 1975aa9ce707Sdrh addrBreak = sqlite3VdbeMakeLabel(v); 1976aa9ce707Sdrh computeLimitRegisters(pParse, p, addrBreak); 1977aa9ce707Sdrh pLimit = p->pLimit; 1978aa9ce707Sdrh pOffset = p->pOffset; 1979aa9ce707Sdrh regLimit = p->iLimit; 1980aa9ce707Sdrh regOffset = p->iOffset; 1981aa9ce707Sdrh p->pLimit = p->pOffset = 0; 1982aa9ce707Sdrh p->iLimit = p->iOffset = 0; 198353bed45eSdan pOrderBy = p->pOrderBy; 1984781def29Sdrh 1985781def29Sdrh /* Locate the cursor number of the Current table */ 1986781def29Sdrh for(i=0; ALWAYS(i<pSrc->nSrc); i++){ 1987781def29Sdrh if( pSrc->a[i].isRecursive ){ 1988781def29Sdrh iCurrent = pSrc->a[i].iCursor; 1989781def29Sdrh break; 1990781def29Sdrh } 1991781def29Sdrh } 1992781def29Sdrh 1993fe1c6bb9Sdrh /* Allocate cursors numbers for Queue and Distinct. The cursor number for 1994781def29Sdrh ** the Distinct table must be exactly one greater than Queue in order 19958e1ee88cSdrh ** for the SRT_DistFifo and SRT_DistQueue destinations to work. */ 1996781def29Sdrh iQueue = pParse->nTab++; 1997781def29Sdrh if( p->op==TK_UNION ){ 19988e1ee88cSdrh eDest = pOrderBy ? SRT_DistQueue : SRT_DistFifo; 1999781def29Sdrh iDistinct = pParse->nTab++; 2000fe1c6bb9Sdrh }else{ 20018e1ee88cSdrh eDest = pOrderBy ? SRT_Queue : SRT_Fifo; 2002781def29Sdrh } 2003781def29Sdrh sqlite3SelectDestInit(&destQueue, eDest, iQueue); 2004781def29Sdrh 2005781def29Sdrh /* Allocate cursors for Current, Queue, and Distinct. */ 2006781def29Sdrh regCurrent = ++pParse->nMem; 2007781def29Sdrh sqlite3VdbeAddOp3(v, OP_OpenPseudo, iCurrent, regCurrent, nCol); 2008fe1c6bb9Sdrh if( pOrderBy ){ 200953bed45eSdan KeyInfo *pKeyInfo = multiSelectOrderByKeyInfo(pParse, p, 1); 2010fe1c6bb9Sdrh sqlite3VdbeAddOp4(v, OP_OpenEphemeral, iQueue, pOrderBy->nExpr+2, 0, 2011fe1c6bb9Sdrh (char*)pKeyInfo, P4_KEYINFO); 2012fe1c6bb9Sdrh destQueue.pOrderBy = pOrderBy; 2013fe1c6bb9Sdrh }else{ 2014781def29Sdrh sqlite3VdbeAddOp2(v, OP_OpenEphemeral, iQueue, nCol); 2015fe1c6bb9Sdrh } 2016fe1c6bb9Sdrh VdbeComment((v, "Queue table")); 2017781def29Sdrh if( iDistinct ){ 2018781def29Sdrh p->addrOpenEphm[0] = sqlite3VdbeAddOp2(v, OP_OpenEphemeral, iDistinct, 0); 2019781def29Sdrh p->selFlags |= SF_UsesEphemeral; 2020781def29Sdrh } 2021781def29Sdrh 202253bed45eSdan /* Detach the ORDER BY clause from the compound SELECT */ 202353bed45eSdan p->pOrderBy = 0; 202453bed45eSdan 2025781def29Sdrh /* Store the results of the setup-query in Queue. */ 2026d227a291Sdrh pSetup->pNext = 0; 2027781def29Sdrh rc = sqlite3Select(pParse, pSetup, &destQueue); 2028d227a291Sdrh pSetup->pNext = p; 2029fe1c6bb9Sdrh if( rc ) goto end_of_recursive_query; 2030781def29Sdrh 2031781def29Sdrh /* Find the next row in the Queue and output that row */ 2032688852abSdrh addrTop = sqlite3VdbeAddOp2(v, OP_Rewind, iQueue, addrBreak); VdbeCoverage(v); 2033781def29Sdrh 2034781def29Sdrh /* Transfer the next row in Queue over to Current */ 2035781def29Sdrh sqlite3VdbeAddOp1(v, OP_NullRow, iCurrent); /* To reset column cache */ 2036fe1c6bb9Sdrh if( pOrderBy ){ 2037fe1c6bb9Sdrh sqlite3VdbeAddOp3(v, OP_Column, iQueue, pOrderBy->nExpr+1, regCurrent); 2038fe1c6bb9Sdrh }else{ 2039781def29Sdrh sqlite3VdbeAddOp2(v, OP_RowData, iQueue, regCurrent); 2040fe1c6bb9Sdrh } 2041781def29Sdrh sqlite3VdbeAddOp1(v, OP_Delete, iQueue); 2042781def29Sdrh 2043fe1c6bb9Sdrh /* Output the single row in Current */ 2044fe1c6bb9Sdrh addrCont = sqlite3VdbeMakeLabel(v); 2045aa9ce707Sdrh codeOffset(v, regOffset, addrCont); 2046fe1c6bb9Sdrh selectInnerLoop(pParse, p, p->pEList, iCurrent, 2047079a3072Sdrh 0, 0, pDest, addrCont, addrBreak); 2048688852abSdrh if( regLimit ){ 2049688852abSdrh sqlite3VdbeAddOp3(v, OP_IfZero, regLimit, addrBreak, -1); 2050688852abSdrh VdbeCoverage(v); 2051688852abSdrh } 2052fe1c6bb9Sdrh sqlite3VdbeResolveLabel(v, addrCont); 2053fe1c6bb9Sdrh 2054781def29Sdrh /* Execute the recursive SELECT taking the single row in Current as 2055781def29Sdrh ** the value for the recursive-table. Store the results in the Queue. 2056781def29Sdrh */ 2057781def29Sdrh p->pPrior = 0; 2058781def29Sdrh sqlite3Select(pParse, p, &destQueue); 2059781def29Sdrh assert( p->pPrior==0 ); 2060781def29Sdrh p->pPrior = pSetup; 2061781def29Sdrh 2062781def29Sdrh /* Keep running the loop until the Queue is empty */ 2063781def29Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, addrTop); 2064781def29Sdrh sqlite3VdbeResolveLabel(v, addrBreak); 2065fe1c6bb9Sdrh 2066fe1c6bb9Sdrh end_of_recursive_query: 20679afccba2Sdan sqlite3ExprListDelete(pParse->db, p->pOrderBy); 2068fe1c6bb9Sdrh p->pOrderBy = pOrderBy; 2069aa9ce707Sdrh p->pLimit = pLimit; 2070aa9ce707Sdrh p->pOffset = pOffset; 2071fe1c6bb9Sdrh return; 2072781def29Sdrh } 2073b68b9778Sdan #endif /* SQLITE_OMIT_CTE */ 2074781def29Sdrh 2075781def29Sdrh /* Forward references */ 2076b21e7c70Sdrh static int multiSelectOrderBy( 2077b21e7c70Sdrh Parse *pParse, /* Parsing context */ 2078b21e7c70Sdrh Select *p, /* The right-most of SELECTs to be coded */ 2079a9671a22Sdrh SelectDest *pDest /* What to do with query results */ 2080b21e7c70Sdrh ); 2081b21e7c70Sdrh 2082b21e7c70Sdrh 2083d3d39e93Sdrh /* 208416ee60ffSdrh ** This routine is called to process a compound query form from 208516ee60ffSdrh ** two or more separate queries using UNION, UNION ALL, EXCEPT, or 208616ee60ffSdrh ** INTERSECT 2087c926afbcSdrh ** 2088e78e8284Sdrh ** "p" points to the right-most of the two queries. the query on the 2089e78e8284Sdrh ** left is p->pPrior. The left query could also be a compound query 2090e78e8284Sdrh ** in which case this routine will be called recursively. 2091e78e8284Sdrh ** 2092e78e8284Sdrh ** The results of the total query are to be written into a destination 2093e78e8284Sdrh ** of type eDest with parameter iParm. 2094e78e8284Sdrh ** 2095e78e8284Sdrh ** Example 1: Consider a three-way compound SQL statement. 2096e78e8284Sdrh ** 2097e78e8284Sdrh ** SELECT a FROM t1 UNION SELECT b FROM t2 UNION SELECT c FROM t3 2098e78e8284Sdrh ** 2099e78e8284Sdrh ** This statement is parsed up as follows: 2100e78e8284Sdrh ** 2101e78e8284Sdrh ** SELECT c FROM t3 2102e78e8284Sdrh ** | 2103e78e8284Sdrh ** `-----> SELECT b FROM t2 2104e78e8284Sdrh ** | 21054b11c6d3Sjplyon ** `------> SELECT a FROM t1 2106e78e8284Sdrh ** 2107e78e8284Sdrh ** The arrows in the diagram above represent the Select.pPrior pointer. 2108e78e8284Sdrh ** So if this routine is called with p equal to the t3 query, then 2109e78e8284Sdrh ** pPrior will be the t2 query. p->op will be TK_UNION in this case. 2110e78e8284Sdrh ** 2111e78e8284Sdrh ** Notice that because of the way SQLite parses compound SELECTs, the 2112e78e8284Sdrh ** individual selects always group from left to right. 211382c3d636Sdrh */ 211484ac9d02Sdanielk1977 static int multiSelect( 2115fbc4ee7bSdrh Parse *pParse, /* Parsing context */ 2116fbc4ee7bSdrh Select *p, /* The right-most of SELECTs to be coded */ 2117a9671a22Sdrh SelectDest *pDest /* What to do with query results */ 211884ac9d02Sdanielk1977 ){ 211984ac9d02Sdanielk1977 int rc = SQLITE_OK; /* Success code from a subroutine */ 212010e5e3cfSdrh Select *pPrior; /* Another SELECT immediately to our left */ 212110e5e3cfSdrh Vdbe *v; /* Generate code to this VDBE */ 21221013c932Sdrh SelectDest dest; /* Alternative data destination */ 2123eca7e01aSdanielk1977 Select *pDelete = 0; /* Chain of simple selects to delete */ 2124633e6d57Sdrh sqlite3 *db; /* Database connection */ 21257f61e92cSdan #ifndef SQLITE_OMIT_EXPLAIN 2126edf83d1eSdrh int iSub1 = 0; /* EQP id of left-hand query */ 2127edf83d1eSdrh int iSub2 = 0; /* EQP id of right-hand query */ 21287f61e92cSdan #endif 212982c3d636Sdrh 21307b58daeaSdrh /* Make sure there is no ORDER BY or LIMIT clause on prior SELECTs. Only 2131fbc4ee7bSdrh ** the last (right-most) SELECT in the series may have an ORDER BY or LIMIT. 213282c3d636Sdrh */ 2133701bb3b4Sdrh assert( p && p->pPrior ); /* Calling function guarantees this much */ 2134eae73fbfSdan assert( (p->selFlags & SF_Recursive)==0 || p->op==TK_ALL || p->op==TK_UNION ); 2135633e6d57Sdrh db = pParse->db; 2136d8bc7086Sdrh pPrior = p->pPrior; 2137bc10377aSdrh dest = *pDest; 2138d8bc7086Sdrh if( pPrior->pOrderBy ){ 21394adee20fSdanielk1977 sqlite3ErrorMsg(pParse,"ORDER BY clause should come after %s not before", 2140da93d238Sdrh selectOpName(p->op)); 214184ac9d02Sdanielk1977 rc = 1; 214284ac9d02Sdanielk1977 goto multi_select_end; 214382c3d636Sdrh } 2144a2dc3b1aSdanielk1977 if( pPrior->pLimit ){ 21454adee20fSdanielk1977 sqlite3ErrorMsg(pParse,"LIMIT clause should come after %s not before", 21467b58daeaSdrh selectOpName(p->op)); 214784ac9d02Sdanielk1977 rc = 1; 214884ac9d02Sdanielk1977 goto multi_select_end; 21497b58daeaSdrh } 215082c3d636Sdrh 21514adee20fSdanielk1977 v = sqlite3GetVdbe(pParse); 2152701bb3b4Sdrh assert( v!=0 ); /* The VDBE already created by calling function */ 2153d8bc7086Sdrh 21541cc3d75fSdrh /* Create the destination temporary table if necessary 21551cc3d75fSdrh */ 21566c8c8ce0Sdanielk1977 if( dest.eDest==SRT_EphemTab ){ 2157b4964b72Sdanielk1977 assert( p->pEList ); 21582b596da8Sdrh sqlite3VdbeAddOp2(v, OP_OpenEphemeral, dest.iSDParm, p->pEList->nExpr); 2159d4187c71Sdrh sqlite3VdbeChangeP5(v, BTREE_UNORDERED); 21606c8c8ce0Sdanielk1977 dest.eDest = SRT_Table; 21611cc3d75fSdrh } 21621cc3d75fSdrh 2163f6e369a1Sdrh /* Make sure all SELECTs in the statement have the same number of elements 2164f6e369a1Sdrh ** in their result sets. 2165f6e369a1Sdrh */ 2166f6e369a1Sdrh assert( p->pEList && pPrior->pEList ); 2167f6e369a1Sdrh if( p->pEList->nExpr!=pPrior->pEList->nExpr ){ 21687b113babSdrh if( p->selFlags & SF_Values ){ 21697b113babSdrh sqlite3ErrorMsg(pParse, "all VALUES must have the same number of terms"); 21707b113babSdrh }else{ 2171f6e369a1Sdrh sqlite3ErrorMsg(pParse, "SELECTs to the left and right of %s" 2172f6e369a1Sdrh " do not have the same number of result columns", selectOpName(p->op)); 21737b113babSdrh } 2174f6e369a1Sdrh rc = 1; 2175f6e369a1Sdrh goto multi_select_end; 2176f6e369a1Sdrh } 2177f6e369a1Sdrh 2178eede6a53Sdan #ifndef SQLITE_OMIT_CTE 2179eae73fbfSdan if( p->selFlags & SF_Recursive ){ 2180781def29Sdrh generateWithRecursiveQuery(pParse, p, &dest); 21818ce7184bSdan }else 21828ce7184bSdan #endif 21838ce7184bSdan 2184a9671a22Sdrh /* Compound SELECTs that have an ORDER BY clause are handled separately. 2185a9671a22Sdrh */ 2186f6e369a1Sdrh if( p->pOrderBy ){ 2187a9671a22Sdrh return multiSelectOrderBy(pParse, p, pDest); 2188eede6a53Sdan }else 2189f6e369a1Sdrh 2190f46f905aSdrh /* Generate code for the left and right SELECT statements. 2191d8bc7086Sdrh */ 219282c3d636Sdrh switch( p->op ){ 2193f46f905aSdrh case TK_ALL: { 2194ec7429aeSdrh int addr = 0; 219595aa47b1Sdrh int nLimit; 2196a2dc3b1aSdanielk1977 assert( !pPrior->pLimit ); 2197547180baSdrh pPrior->iLimit = p->iLimit; 2198547180baSdrh pPrior->iOffset = p->iOffset; 2199a2dc3b1aSdanielk1977 pPrior->pLimit = p->pLimit; 2200a2dc3b1aSdanielk1977 pPrior->pOffset = p->pOffset; 22017f61e92cSdan explainSetInteger(iSub1, pParse->iNextSelectId); 22027d10d5a6Sdrh rc = sqlite3Select(pParse, pPrior, &dest); 2203ad68cb6bSdanielk1977 p->pLimit = 0; 2204ad68cb6bSdanielk1977 p->pOffset = 0; 220584ac9d02Sdanielk1977 if( rc ){ 220684ac9d02Sdanielk1977 goto multi_select_end; 220784ac9d02Sdanielk1977 } 2208f46f905aSdrh p->pPrior = 0; 22097b58daeaSdrh p->iLimit = pPrior->iLimit; 22107b58daeaSdrh p->iOffset = pPrior->iOffset; 221192b01d53Sdrh if( p->iLimit ){ 2212688852abSdrh addr = sqlite3VdbeAddOp1(v, OP_IfZero, p->iLimit); VdbeCoverage(v); 2213d4e70ebdSdrh VdbeComment((v, "Jump ahead if LIMIT reached")); 2214ec7429aeSdrh } 22157f61e92cSdan explainSetInteger(iSub2, pParse->iNextSelectId); 22167d10d5a6Sdrh rc = sqlite3Select(pParse, p, &dest); 2217373cc2ddSdrh testcase( rc!=SQLITE_OK ); 2218eca7e01aSdanielk1977 pDelete = p->pPrior; 2219f46f905aSdrh p->pPrior = pPrior; 222095aa47b1Sdrh p->nSelectRow += pPrior->nSelectRow; 222195aa47b1Sdrh if( pPrior->pLimit 222295aa47b1Sdrh && sqlite3ExprIsInteger(pPrior->pLimit, &nLimit) 2223613ba1eaSdrh && nLimit>0 && p->nSelectRow > (u64)nLimit 222495aa47b1Sdrh ){ 2225c63367efSdrh p->nSelectRow = nLimit; 222695aa47b1Sdrh } 2227ec7429aeSdrh if( addr ){ 2228ec7429aeSdrh sqlite3VdbeJumpHere(v, addr); 2229ec7429aeSdrh } 2230f46f905aSdrh break; 2231f46f905aSdrh } 223282c3d636Sdrh case TK_EXCEPT: 223382c3d636Sdrh case TK_UNION: { 2234d8bc7086Sdrh int unionTab; /* Cursor number of the temporary table holding result */ 2235ea678832Sdrh u8 op = 0; /* One of the SRT_ operations to apply to self */ 2236d8bc7086Sdrh int priorOp; /* The SRT_ operation to apply to prior selects */ 2237a2dc3b1aSdanielk1977 Expr *pLimit, *pOffset; /* Saved values of p->nLimit and p->nOffset */ 2238dc1bdc4fSdanielk1977 int addr; 22396c8c8ce0Sdanielk1977 SelectDest uniondest; 224082c3d636Sdrh 2241373cc2ddSdrh testcase( p->op==TK_EXCEPT ); 2242373cc2ddSdrh testcase( p->op==TK_UNION ); 224393a960a0Sdrh priorOp = SRT_Union; 2244d227a291Sdrh if( dest.eDest==priorOp ){ 2245d8bc7086Sdrh /* We can reuse a temporary table generated by a SELECT to our 2246c926afbcSdrh ** right. 2247d8bc7086Sdrh */ 2248e2f02bacSdrh assert( p->pLimit==0 ); /* Not allowed on leftward elements */ 2249e2f02bacSdrh assert( p->pOffset==0 ); /* Not allowed on leftward elements */ 22502b596da8Sdrh unionTab = dest.iSDParm; 225182c3d636Sdrh }else{ 2252d8bc7086Sdrh /* We will need to create our own temporary table to hold the 2253d8bc7086Sdrh ** intermediate results. 2254d8bc7086Sdrh */ 225582c3d636Sdrh unionTab = pParse->nTab++; 225693a960a0Sdrh assert( p->pOrderBy==0 ); 225766a5167bSdrh addr = sqlite3VdbeAddOp2(v, OP_OpenEphemeral, unionTab, 0); 2258b9bb7c18Sdrh assert( p->addrOpenEphm[0] == -1 ); 2259b9bb7c18Sdrh p->addrOpenEphm[0] = addr; 2260d227a291Sdrh findRightmost(p)->selFlags |= SF_UsesEphemeral; 226184ac9d02Sdanielk1977 assert( p->pEList ); 2262d8bc7086Sdrh } 2263d8bc7086Sdrh 2264d8bc7086Sdrh /* Code the SELECT statements to our left 2265d8bc7086Sdrh */ 2266b3bce662Sdanielk1977 assert( !pPrior->pOrderBy ); 22671013c932Sdrh sqlite3SelectDestInit(&uniondest, priorOp, unionTab); 22687f61e92cSdan explainSetInteger(iSub1, pParse->iNextSelectId); 22697d10d5a6Sdrh rc = sqlite3Select(pParse, pPrior, &uniondest); 227084ac9d02Sdanielk1977 if( rc ){ 227184ac9d02Sdanielk1977 goto multi_select_end; 227284ac9d02Sdanielk1977 } 2273d8bc7086Sdrh 2274d8bc7086Sdrh /* Code the current SELECT statement 2275d8bc7086Sdrh */ 22764cfb22f7Sdrh if( p->op==TK_EXCEPT ){ 22774cfb22f7Sdrh op = SRT_Except; 22784cfb22f7Sdrh }else{ 22794cfb22f7Sdrh assert( p->op==TK_UNION ); 22804cfb22f7Sdrh op = SRT_Union; 2281d8bc7086Sdrh } 228282c3d636Sdrh p->pPrior = 0; 2283a2dc3b1aSdanielk1977 pLimit = p->pLimit; 2284a2dc3b1aSdanielk1977 p->pLimit = 0; 2285a2dc3b1aSdanielk1977 pOffset = p->pOffset; 2286a2dc3b1aSdanielk1977 p->pOffset = 0; 22876c8c8ce0Sdanielk1977 uniondest.eDest = op; 22887f61e92cSdan explainSetInteger(iSub2, pParse->iNextSelectId); 22897d10d5a6Sdrh rc = sqlite3Select(pParse, p, &uniondest); 2290373cc2ddSdrh testcase( rc!=SQLITE_OK ); 22915bd1bf2eSdrh /* Query flattening in sqlite3Select() might refill p->pOrderBy. 22925bd1bf2eSdrh ** Be sure to delete p->pOrderBy, therefore, to avoid a memory leak. */ 2293633e6d57Sdrh sqlite3ExprListDelete(db, p->pOrderBy); 2294eca7e01aSdanielk1977 pDelete = p->pPrior; 229582c3d636Sdrh p->pPrior = pPrior; 2296a9671a22Sdrh p->pOrderBy = 0; 229795aa47b1Sdrh if( p->op==TK_UNION ) p->nSelectRow += pPrior->nSelectRow; 2298633e6d57Sdrh sqlite3ExprDelete(db, p->pLimit); 2299a2dc3b1aSdanielk1977 p->pLimit = pLimit; 2300a2dc3b1aSdanielk1977 p->pOffset = pOffset; 230192b01d53Sdrh p->iLimit = 0; 230292b01d53Sdrh p->iOffset = 0; 2303d8bc7086Sdrh 2304d8bc7086Sdrh /* Convert the data in the temporary table into whatever form 2305d8bc7086Sdrh ** it is that we currently need. 2306d8bc7086Sdrh */ 23072b596da8Sdrh assert( unionTab==dest.iSDParm || dest.eDest!=priorOp ); 2308373cc2ddSdrh if( dest.eDest!=priorOp ){ 23096b56344dSdrh int iCont, iBreak, iStart; 231082c3d636Sdrh assert( p->pEList ); 23117d10d5a6Sdrh if( dest.eDest==SRT_Output ){ 231292378253Sdrh Select *pFirst = p; 231392378253Sdrh while( pFirst->pPrior ) pFirst = pFirst->pPrior; 231492378253Sdrh generateColumnNames(pParse, 0, pFirst->pEList); 231541202ccaSdrh } 23164adee20fSdanielk1977 iBreak = sqlite3VdbeMakeLabel(v); 23174adee20fSdanielk1977 iCont = sqlite3VdbeMakeLabel(v); 2318ec7429aeSdrh computeLimitRegisters(pParse, p, iBreak); 2319688852abSdrh sqlite3VdbeAddOp2(v, OP_Rewind, unionTab, iBreak); VdbeCoverage(v); 23204adee20fSdanielk1977 iStart = sqlite3VdbeCurrentAddr(v); 2321340309fdSdrh selectInnerLoop(pParse, p, p->pEList, unionTab, 2322079a3072Sdrh 0, 0, &dest, iCont, iBreak); 23234adee20fSdanielk1977 sqlite3VdbeResolveLabel(v, iCont); 2324688852abSdrh sqlite3VdbeAddOp2(v, OP_Next, unionTab, iStart); VdbeCoverage(v); 23254adee20fSdanielk1977 sqlite3VdbeResolveLabel(v, iBreak); 232666a5167bSdrh sqlite3VdbeAddOp2(v, OP_Close, unionTab, 0); 232782c3d636Sdrh } 232882c3d636Sdrh break; 232982c3d636Sdrh } 2330373cc2ddSdrh default: assert( p->op==TK_INTERSECT ); { 233182c3d636Sdrh int tab1, tab2; 23326b56344dSdrh int iCont, iBreak, iStart; 2333a2dc3b1aSdanielk1977 Expr *pLimit, *pOffset; 2334dc1bdc4fSdanielk1977 int addr; 23351013c932Sdrh SelectDest intersectdest; 23369cbf3425Sdrh int r1; 233782c3d636Sdrh 2338d8bc7086Sdrh /* INTERSECT is different from the others since it requires 23396206d50aSdrh ** two temporary tables. Hence it has its own case. Begin 2340d8bc7086Sdrh ** by allocating the tables we will need. 2341d8bc7086Sdrh */ 234282c3d636Sdrh tab1 = pParse->nTab++; 234382c3d636Sdrh tab2 = pParse->nTab++; 234493a960a0Sdrh assert( p->pOrderBy==0 ); 2345dc1bdc4fSdanielk1977 234666a5167bSdrh addr = sqlite3VdbeAddOp2(v, OP_OpenEphemeral, tab1, 0); 2347b9bb7c18Sdrh assert( p->addrOpenEphm[0] == -1 ); 2348b9bb7c18Sdrh p->addrOpenEphm[0] = addr; 2349d227a291Sdrh findRightmost(p)->selFlags |= SF_UsesEphemeral; 235084ac9d02Sdanielk1977 assert( p->pEList ); 2351d8bc7086Sdrh 2352d8bc7086Sdrh /* Code the SELECTs to our left into temporary table "tab1". 2353d8bc7086Sdrh */ 23541013c932Sdrh sqlite3SelectDestInit(&intersectdest, SRT_Union, tab1); 23557f61e92cSdan explainSetInteger(iSub1, pParse->iNextSelectId); 23567d10d5a6Sdrh rc = sqlite3Select(pParse, pPrior, &intersectdest); 235784ac9d02Sdanielk1977 if( rc ){ 235884ac9d02Sdanielk1977 goto multi_select_end; 235984ac9d02Sdanielk1977 } 2360d8bc7086Sdrh 2361d8bc7086Sdrh /* Code the current SELECT into temporary table "tab2" 2362d8bc7086Sdrh */ 236366a5167bSdrh addr = sqlite3VdbeAddOp2(v, OP_OpenEphemeral, tab2, 0); 2364b9bb7c18Sdrh assert( p->addrOpenEphm[1] == -1 ); 2365b9bb7c18Sdrh p->addrOpenEphm[1] = addr; 236682c3d636Sdrh p->pPrior = 0; 2367a2dc3b1aSdanielk1977 pLimit = p->pLimit; 2368a2dc3b1aSdanielk1977 p->pLimit = 0; 2369a2dc3b1aSdanielk1977 pOffset = p->pOffset; 2370a2dc3b1aSdanielk1977 p->pOffset = 0; 23712b596da8Sdrh intersectdest.iSDParm = tab2; 23727f61e92cSdan explainSetInteger(iSub2, pParse->iNextSelectId); 23737d10d5a6Sdrh rc = sqlite3Select(pParse, p, &intersectdest); 2374373cc2ddSdrh testcase( rc!=SQLITE_OK ); 2375eca7e01aSdanielk1977 pDelete = p->pPrior; 237682c3d636Sdrh p->pPrior = pPrior; 237795aa47b1Sdrh if( p->nSelectRow>pPrior->nSelectRow ) p->nSelectRow = pPrior->nSelectRow; 2378633e6d57Sdrh sqlite3ExprDelete(db, p->pLimit); 2379a2dc3b1aSdanielk1977 p->pLimit = pLimit; 2380a2dc3b1aSdanielk1977 p->pOffset = pOffset; 2381d8bc7086Sdrh 2382d8bc7086Sdrh /* Generate code to take the intersection of the two temporary 2383d8bc7086Sdrh ** tables. 2384d8bc7086Sdrh */ 238582c3d636Sdrh assert( p->pEList ); 23867d10d5a6Sdrh if( dest.eDest==SRT_Output ){ 238792378253Sdrh Select *pFirst = p; 238892378253Sdrh while( pFirst->pPrior ) pFirst = pFirst->pPrior; 238992378253Sdrh generateColumnNames(pParse, 0, pFirst->pEList); 239041202ccaSdrh } 23914adee20fSdanielk1977 iBreak = sqlite3VdbeMakeLabel(v); 23924adee20fSdanielk1977 iCont = sqlite3VdbeMakeLabel(v); 2393ec7429aeSdrh computeLimitRegisters(pParse, p, iBreak); 2394688852abSdrh sqlite3VdbeAddOp2(v, OP_Rewind, tab1, iBreak); VdbeCoverage(v); 23959cbf3425Sdrh r1 = sqlite3GetTempReg(pParse); 23969cbf3425Sdrh iStart = sqlite3VdbeAddOp2(v, OP_RowKey, tab1, r1); 2397688852abSdrh sqlite3VdbeAddOp4Int(v, OP_NotFound, tab2, iCont, r1, 0); VdbeCoverage(v); 23989cbf3425Sdrh sqlite3ReleaseTempReg(pParse, r1); 2399340309fdSdrh selectInnerLoop(pParse, p, p->pEList, tab1, 2400079a3072Sdrh 0, 0, &dest, iCont, iBreak); 24014adee20fSdanielk1977 sqlite3VdbeResolveLabel(v, iCont); 2402688852abSdrh sqlite3VdbeAddOp2(v, OP_Next, tab1, iStart); VdbeCoverage(v); 24034adee20fSdanielk1977 sqlite3VdbeResolveLabel(v, iBreak); 240466a5167bSdrh sqlite3VdbeAddOp2(v, OP_Close, tab2, 0); 240566a5167bSdrh sqlite3VdbeAddOp2(v, OP_Close, tab1, 0); 240682c3d636Sdrh break; 240782c3d636Sdrh } 240882c3d636Sdrh } 24098cdbf836Sdrh 24107f61e92cSdan explainComposite(pParse, p->op, iSub1, iSub2, p->op!=TK_ALL); 24117f61e92cSdan 2412a9671a22Sdrh /* Compute collating sequences used by 2413a9671a22Sdrh ** temporary tables needed to implement the compound select. 2414a9671a22Sdrh ** Attach the KeyInfo structure to all temporary tables. 24158cdbf836Sdrh ** 24168cdbf836Sdrh ** This section is run by the right-most SELECT statement only. 24178cdbf836Sdrh ** SELECT statements to the left always skip this part. The right-most 24188cdbf836Sdrh ** SELECT might also skip this part if it has no ORDER BY clause and 24198cdbf836Sdrh ** no temp tables are required. 2420fbc4ee7bSdrh */ 24217d10d5a6Sdrh if( p->selFlags & SF_UsesEphemeral ){ 2422fbc4ee7bSdrh int i; /* Loop counter */ 2423fbc4ee7bSdrh KeyInfo *pKeyInfo; /* Collating sequence for the result set */ 24240342b1f5Sdrh Select *pLoop; /* For looping through SELECT statements */ 2425f68d7d17Sdrh CollSeq **apColl; /* For looping through pKeyInfo->aColl[] */ 242693a960a0Sdrh int nCol; /* Number of columns in result set */ 2427fbc4ee7bSdrh 2428d227a291Sdrh assert( p->pNext==0 ); 242993a960a0Sdrh nCol = p->pEList->nExpr; 2430ad124329Sdrh pKeyInfo = sqlite3KeyInfoAlloc(db, nCol, 1); 2431dc1bdc4fSdanielk1977 if( !pKeyInfo ){ 2432dc1bdc4fSdanielk1977 rc = SQLITE_NOMEM; 2433dc1bdc4fSdanielk1977 goto multi_select_end; 2434dc1bdc4fSdanielk1977 } 24350342b1f5Sdrh for(i=0, apColl=pKeyInfo->aColl; i<nCol; i++, apColl++){ 24360342b1f5Sdrh *apColl = multiSelectCollSeq(pParse, p, i); 24370342b1f5Sdrh if( 0==*apColl ){ 2438633e6d57Sdrh *apColl = db->pDfltColl; 2439dc1bdc4fSdanielk1977 } 2440dc1bdc4fSdanielk1977 } 2441dc1bdc4fSdanielk1977 24420342b1f5Sdrh for(pLoop=p; pLoop; pLoop=pLoop->pPrior){ 24430342b1f5Sdrh for(i=0; i<2; i++){ 2444b9bb7c18Sdrh int addr = pLoop->addrOpenEphm[i]; 24450342b1f5Sdrh if( addr<0 ){ 24460342b1f5Sdrh /* If [0] is unused then [1] is also unused. So we can 24470342b1f5Sdrh ** always safely abort as soon as the first unused slot is found */ 2448b9bb7c18Sdrh assert( pLoop->addrOpenEphm[1]<0 ); 24490342b1f5Sdrh break; 24500342b1f5Sdrh } 24510342b1f5Sdrh sqlite3VdbeChangeP2(v, addr, nCol); 24522ec2fb22Sdrh sqlite3VdbeChangeP4(v, addr, (char*)sqlite3KeyInfoRef(pKeyInfo), 24532ec2fb22Sdrh P4_KEYINFO); 24540ee5a1e7Sdrh pLoop->addrOpenEphm[i] = -1; 24550342b1f5Sdrh } 2456dc1bdc4fSdanielk1977 } 24572ec2fb22Sdrh sqlite3KeyInfoUnref(pKeyInfo); 2458dc1bdc4fSdanielk1977 } 2459dc1bdc4fSdanielk1977 2460dc1bdc4fSdanielk1977 multi_select_end: 24612b596da8Sdrh pDest->iSdst = dest.iSdst; 24622b596da8Sdrh pDest->nSdst = dest.nSdst; 2463633e6d57Sdrh sqlite3SelectDelete(db, pDelete); 246484ac9d02Sdanielk1977 return rc; 24652282792aSdrh } 2466b7f9164eSdrh #endif /* SQLITE_OMIT_COMPOUND_SELECT */ 24672282792aSdrh 2468b21e7c70Sdrh /* 2469b21e7c70Sdrh ** Code an output subroutine for a coroutine implementation of a 2470b21e7c70Sdrh ** SELECT statment. 24710acb7e48Sdrh ** 24722b596da8Sdrh ** The data to be output is contained in pIn->iSdst. There are 24732b596da8Sdrh ** pIn->nSdst columns to be output. pDest is where the output should 24740acb7e48Sdrh ** be sent. 24750acb7e48Sdrh ** 24760acb7e48Sdrh ** regReturn is the number of the register holding the subroutine 24770acb7e48Sdrh ** return address. 24780acb7e48Sdrh ** 2479f053d5b6Sdrh ** If regPrev>0 then it is the first register in a vector that 24800acb7e48Sdrh ** records the previous output. mem[regPrev] is a flag that is false 24810acb7e48Sdrh ** if there has been no previous output. If regPrev>0 then code is 24820acb7e48Sdrh ** generated to suppress duplicates. pKeyInfo is used for comparing 24830acb7e48Sdrh ** keys. 24840acb7e48Sdrh ** 24850acb7e48Sdrh ** If the LIMIT found in p->iLimit is reached, jump immediately to 24860acb7e48Sdrh ** iBreak. 2487b21e7c70Sdrh */ 24880acb7e48Sdrh static int generateOutputSubroutine( 248992b01d53Sdrh Parse *pParse, /* Parsing context */ 249092b01d53Sdrh Select *p, /* The SELECT statement */ 249192b01d53Sdrh SelectDest *pIn, /* Coroutine supplying data */ 249292b01d53Sdrh SelectDest *pDest, /* Where to send the data */ 249392b01d53Sdrh int regReturn, /* The return address register */ 24940acb7e48Sdrh int regPrev, /* Previous result register. No uniqueness if 0 */ 24950acb7e48Sdrh KeyInfo *pKeyInfo, /* For comparing with previous entry */ 249692b01d53Sdrh int iBreak /* Jump here if we hit the LIMIT */ 2497b21e7c70Sdrh ){ 2498b21e7c70Sdrh Vdbe *v = pParse->pVdbe; 249992b01d53Sdrh int iContinue; 250092b01d53Sdrh int addr; 2501b21e7c70Sdrh 250292b01d53Sdrh addr = sqlite3VdbeCurrentAddr(v); 250392b01d53Sdrh iContinue = sqlite3VdbeMakeLabel(v); 25040acb7e48Sdrh 25050acb7e48Sdrh /* Suppress duplicates for UNION, EXCEPT, and INTERSECT 25060acb7e48Sdrh */ 25070acb7e48Sdrh if( regPrev ){ 25080acb7e48Sdrh int j1, j2; 2509688852abSdrh j1 = sqlite3VdbeAddOp1(v, OP_IfNot, regPrev); VdbeCoverage(v); 25102b596da8Sdrh j2 = sqlite3VdbeAddOp4(v, OP_Compare, pIn->iSdst, regPrev+1, pIn->nSdst, 25112ec2fb22Sdrh (char*)sqlite3KeyInfoRef(pKeyInfo), P4_KEYINFO); 2512688852abSdrh sqlite3VdbeAddOp3(v, OP_Jump, j2+2, iContinue, j2+2); VdbeCoverage(v); 25130acb7e48Sdrh sqlite3VdbeJumpHere(v, j1); 2514e8e4af76Sdrh sqlite3VdbeAddOp3(v, OP_Copy, pIn->iSdst, regPrev+1, pIn->nSdst-1); 2515ec86c724Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 1, regPrev); 25160acb7e48Sdrh } 25171f9caa41Sdanielk1977 if( pParse->db->mallocFailed ) return 0; 25180acb7e48Sdrh 2519d5578433Smistachkin /* Suppress the first OFFSET entries if there is an OFFSET clause 25200acb7e48Sdrh */ 2521aa9ce707Sdrh codeOffset(v, p->iOffset, iContinue); 2522b21e7c70Sdrh 2523b21e7c70Sdrh switch( pDest->eDest ){ 2524b21e7c70Sdrh /* Store the result as data using a unique key. 2525b21e7c70Sdrh */ 2526b21e7c70Sdrh case SRT_Table: 2527b21e7c70Sdrh case SRT_EphemTab: { 2528b21e7c70Sdrh int r1 = sqlite3GetTempReg(pParse); 2529b21e7c70Sdrh int r2 = sqlite3GetTempReg(pParse); 2530373cc2ddSdrh testcase( pDest->eDest==SRT_Table ); 2531373cc2ddSdrh testcase( pDest->eDest==SRT_EphemTab ); 25322b596da8Sdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, pIn->iSdst, pIn->nSdst, r1); 25332b596da8Sdrh sqlite3VdbeAddOp2(v, OP_NewRowid, pDest->iSDParm, r2); 25342b596da8Sdrh sqlite3VdbeAddOp3(v, OP_Insert, pDest->iSDParm, r1, r2); 2535b21e7c70Sdrh sqlite3VdbeChangeP5(v, OPFLAG_APPEND); 2536b21e7c70Sdrh sqlite3ReleaseTempReg(pParse, r2); 2537b21e7c70Sdrh sqlite3ReleaseTempReg(pParse, r1); 2538b21e7c70Sdrh break; 2539b21e7c70Sdrh } 2540b21e7c70Sdrh 2541b21e7c70Sdrh #ifndef SQLITE_OMIT_SUBQUERY 2542b21e7c70Sdrh /* If we are creating a set for an "expr IN (SELECT ...)" construct, 2543b21e7c70Sdrh ** then there should be a single item on the stack. Write this 2544b21e7c70Sdrh ** item into the set table with bogus data. 2545b21e7c70Sdrh */ 2546b21e7c70Sdrh case SRT_Set: { 25476fccc35aSdrh int r1; 25482b596da8Sdrh assert( pIn->nSdst==1 ); 2549634d81deSdrh pDest->affSdst = 25502b596da8Sdrh sqlite3CompareAffinity(p->pEList->a[0].pExpr, pDest->affSdst); 2551b21e7c70Sdrh r1 = sqlite3GetTempReg(pParse); 2552634d81deSdrh sqlite3VdbeAddOp4(v, OP_MakeRecord, pIn->iSdst, 1, r1, &pDest->affSdst,1); 25532b596da8Sdrh sqlite3ExprCacheAffinityChange(pParse, pIn->iSdst, 1); 25542b596da8Sdrh sqlite3VdbeAddOp2(v, OP_IdxInsert, pDest->iSDParm, r1); 2555b21e7c70Sdrh sqlite3ReleaseTempReg(pParse, r1); 2556b21e7c70Sdrh break; 2557b21e7c70Sdrh } 2558b21e7c70Sdrh 255985e9e22bSdrh #if 0 /* Never occurs on an ORDER BY query */ 2560b21e7c70Sdrh /* If any row exist in the result set, record that fact and abort. 2561b21e7c70Sdrh */ 2562b21e7c70Sdrh case SRT_Exists: { 25632b596da8Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 1, pDest->iSDParm); 2564b21e7c70Sdrh /* The LIMIT clause will terminate the loop for us */ 2565b21e7c70Sdrh break; 2566b21e7c70Sdrh } 256785e9e22bSdrh #endif 2568b21e7c70Sdrh 2569b21e7c70Sdrh /* If this is a scalar select that is part of an expression, then 2570b21e7c70Sdrh ** store the results in the appropriate memory cell and break out 2571b21e7c70Sdrh ** of the scan loop. 2572b21e7c70Sdrh */ 2573b21e7c70Sdrh case SRT_Mem: { 25742b596da8Sdrh assert( pIn->nSdst==1 ); 25752b596da8Sdrh sqlite3ExprCodeMove(pParse, pIn->iSdst, pDest->iSDParm, 1); 2576b21e7c70Sdrh /* The LIMIT clause will jump out of the loop for us */ 2577b21e7c70Sdrh break; 2578b21e7c70Sdrh } 2579b21e7c70Sdrh #endif /* #ifndef SQLITE_OMIT_SUBQUERY */ 2580b21e7c70Sdrh 25817d10d5a6Sdrh /* The results are stored in a sequence of registers 25822b596da8Sdrh ** starting at pDest->iSdst. Then the co-routine yields. 2583b21e7c70Sdrh */ 258492b01d53Sdrh case SRT_Coroutine: { 25852b596da8Sdrh if( pDest->iSdst==0 ){ 25862b596da8Sdrh pDest->iSdst = sqlite3GetTempRange(pParse, pIn->nSdst); 25872b596da8Sdrh pDest->nSdst = pIn->nSdst; 2588b21e7c70Sdrh } 25892b596da8Sdrh sqlite3ExprCodeMove(pParse, pIn->iSdst, pDest->iSdst, pDest->nSdst); 25902b596da8Sdrh sqlite3VdbeAddOp1(v, OP_Yield, pDest->iSDParm); 259192b01d53Sdrh break; 259292b01d53Sdrh } 259392b01d53Sdrh 2594ccfcbceaSdrh /* If none of the above, then the result destination must be 2595ccfcbceaSdrh ** SRT_Output. This routine is never called with any other 2596ccfcbceaSdrh ** destination other than the ones handled above or SRT_Output. 2597ccfcbceaSdrh ** 2598ccfcbceaSdrh ** For SRT_Output, results are stored in a sequence of registers. 2599ccfcbceaSdrh ** Then the OP_ResultRow opcode is used to cause sqlite3_step() to 2600ccfcbceaSdrh ** return the next row of result. 26017d10d5a6Sdrh */ 2602ccfcbceaSdrh default: { 2603ccfcbceaSdrh assert( pDest->eDest==SRT_Output ); 26042b596da8Sdrh sqlite3VdbeAddOp2(v, OP_ResultRow, pIn->iSdst, pIn->nSdst); 26052b596da8Sdrh sqlite3ExprCacheAffinityChange(pParse, pIn->iSdst, pIn->nSdst); 2606b21e7c70Sdrh break; 2607b21e7c70Sdrh } 2608b21e7c70Sdrh } 260992b01d53Sdrh 261092b01d53Sdrh /* Jump to the end of the loop if the LIMIT is reached. 261192b01d53Sdrh */ 261292b01d53Sdrh if( p->iLimit ){ 2613688852abSdrh sqlite3VdbeAddOp3(v, OP_IfZero, p->iLimit, iBreak, -1); VdbeCoverage(v); 261492b01d53Sdrh } 261592b01d53Sdrh 261692b01d53Sdrh /* Generate the subroutine return 261792b01d53Sdrh */ 26180acb7e48Sdrh sqlite3VdbeResolveLabel(v, iContinue); 261992b01d53Sdrh sqlite3VdbeAddOp1(v, OP_Return, regReturn); 262092b01d53Sdrh 262192b01d53Sdrh return addr; 2622b21e7c70Sdrh } 2623b21e7c70Sdrh 2624b21e7c70Sdrh /* 2625b21e7c70Sdrh ** Alternative compound select code generator for cases when there 2626b21e7c70Sdrh ** is an ORDER BY clause. 2627b21e7c70Sdrh ** 2628b21e7c70Sdrh ** We assume a query of the following form: 2629b21e7c70Sdrh ** 2630b21e7c70Sdrh ** <selectA> <operator> <selectB> ORDER BY <orderbylist> 2631b21e7c70Sdrh ** 2632b21e7c70Sdrh ** <operator> is one of UNION ALL, UNION, EXCEPT, or INTERSECT. The idea 2633b21e7c70Sdrh ** is to code both <selectA> and <selectB> with the ORDER BY clause as 2634b21e7c70Sdrh ** co-routines. Then run the co-routines in parallel and merge the results 2635b21e7c70Sdrh ** into the output. In addition to the two coroutines (called selectA and 2636b21e7c70Sdrh ** selectB) there are 7 subroutines: 2637b21e7c70Sdrh ** 2638b21e7c70Sdrh ** outA: Move the output of the selectA coroutine into the output 2639b21e7c70Sdrh ** of the compound query. 2640b21e7c70Sdrh ** 2641b21e7c70Sdrh ** outB: Move the output of the selectB coroutine into the output 2642b21e7c70Sdrh ** of the compound query. (Only generated for UNION and 2643b21e7c70Sdrh ** UNION ALL. EXCEPT and INSERTSECT never output a row that 2644b21e7c70Sdrh ** appears only in B.) 2645b21e7c70Sdrh ** 2646b21e7c70Sdrh ** AltB: Called when there is data from both coroutines and A<B. 2647b21e7c70Sdrh ** 2648b21e7c70Sdrh ** AeqB: Called when there is data from both coroutines and A==B. 2649b21e7c70Sdrh ** 2650b21e7c70Sdrh ** AgtB: Called when there is data from both coroutines and A>B. 2651b21e7c70Sdrh ** 2652b21e7c70Sdrh ** EofA: Called when data is exhausted from selectA. 2653b21e7c70Sdrh ** 2654b21e7c70Sdrh ** EofB: Called when data is exhausted from selectB. 2655b21e7c70Sdrh ** 2656b21e7c70Sdrh ** The implementation of the latter five subroutines depend on which 2657b21e7c70Sdrh ** <operator> is used: 2658b21e7c70Sdrh ** 2659b21e7c70Sdrh ** 2660b21e7c70Sdrh ** UNION ALL UNION EXCEPT INTERSECT 2661b21e7c70Sdrh ** ------------- ----------------- -------------- ----------------- 2662b21e7c70Sdrh ** AltB: outA, nextA outA, nextA outA, nextA nextA 2663b21e7c70Sdrh ** 26640acb7e48Sdrh ** AeqB: outA, nextA nextA nextA outA, nextA 2665b21e7c70Sdrh ** 2666b21e7c70Sdrh ** AgtB: outB, nextB outB, nextB nextB nextB 2667b21e7c70Sdrh ** 26680acb7e48Sdrh ** EofA: outB, nextB outB, nextB halt halt 2669b21e7c70Sdrh ** 26700acb7e48Sdrh ** EofB: outA, nextA outA, nextA outA, nextA halt 26710acb7e48Sdrh ** 26720acb7e48Sdrh ** In the AltB, AeqB, and AgtB subroutines, an EOF on A following nextA 26730acb7e48Sdrh ** causes an immediate jump to EofA and an EOF on B following nextB causes 26740acb7e48Sdrh ** an immediate jump to EofB. Within EofA and EofB, and EOF on entry or 26750acb7e48Sdrh ** following nextX causes a jump to the end of the select processing. 26760acb7e48Sdrh ** 26770acb7e48Sdrh ** Duplicate removal in the UNION, EXCEPT, and INTERSECT cases is handled 26780acb7e48Sdrh ** within the output subroutine. The regPrev register set holds the previously 26790acb7e48Sdrh ** output value. A comparison is made against this value and the output 26800acb7e48Sdrh ** is skipped if the next results would be the same as the previous. 2681b21e7c70Sdrh ** 2682b21e7c70Sdrh ** The implementation plan is to implement the two coroutines and seven 2683b21e7c70Sdrh ** subroutines first, then put the control logic at the bottom. Like this: 2684b21e7c70Sdrh ** 2685b21e7c70Sdrh ** goto Init 2686b21e7c70Sdrh ** coA: coroutine for left query (A) 2687b21e7c70Sdrh ** coB: coroutine for right query (B) 2688b21e7c70Sdrh ** outA: output one row of A 2689b21e7c70Sdrh ** outB: output one row of B (UNION and UNION ALL only) 2690b21e7c70Sdrh ** EofA: ... 2691b21e7c70Sdrh ** EofB: ... 2692b21e7c70Sdrh ** AltB: ... 2693b21e7c70Sdrh ** AeqB: ... 2694b21e7c70Sdrh ** AgtB: ... 2695b21e7c70Sdrh ** Init: initialize coroutine registers 2696b21e7c70Sdrh ** yield coA 2697b21e7c70Sdrh ** if eof(A) goto EofA 2698b21e7c70Sdrh ** yield coB 2699b21e7c70Sdrh ** if eof(B) goto EofB 2700b21e7c70Sdrh ** Cmpr: Compare A, B 2701b21e7c70Sdrh ** Jump AltB, AeqB, AgtB 2702b21e7c70Sdrh ** End: ... 2703b21e7c70Sdrh ** 2704b21e7c70Sdrh ** We call AltB, AeqB, AgtB, EofA, and EofB "subroutines" but they are not 2705b21e7c70Sdrh ** actually called using Gosub and they do not Return. EofA and EofB loop 2706b21e7c70Sdrh ** until all data is exhausted then jump to the "end" labe. AltB, AeqB, 2707b21e7c70Sdrh ** and AgtB jump to either L2 or to one of EofA or EofB. 2708b21e7c70Sdrh */ 2709de3e41e3Sdanielk1977 #ifndef SQLITE_OMIT_COMPOUND_SELECT 2710b21e7c70Sdrh static int multiSelectOrderBy( 2711b21e7c70Sdrh Parse *pParse, /* Parsing context */ 2712b21e7c70Sdrh Select *p, /* The right-most of SELECTs to be coded */ 2713a9671a22Sdrh SelectDest *pDest /* What to do with query results */ 2714b21e7c70Sdrh ){ 27150acb7e48Sdrh int i, j; /* Loop counters */ 2716b21e7c70Sdrh Select *pPrior; /* Another SELECT immediately to our left */ 2717b21e7c70Sdrh Vdbe *v; /* Generate code to this VDBE */ 2718b21e7c70Sdrh SelectDest destA; /* Destination for coroutine A */ 2719b21e7c70Sdrh SelectDest destB; /* Destination for coroutine B */ 272092b01d53Sdrh int regAddrA; /* Address register for select-A coroutine */ 272192b01d53Sdrh int regAddrB; /* Address register for select-B coroutine */ 272292b01d53Sdrh int addrSelectA; /* Address of the select-A coroutine */ 272392b01d53Sdrh int addrSelectB; /* Address of the select-B coroutine */ 272492b01d53Sdrh int regOutA; /* Address register for the output-A subroutine */ 272592b01d53Sdrh int regOutB; /* Address register for the output-B subroutine */ 272692b01d53Sdrh int addrOutA; /* Address of the output-A subroutine */ 2727b27b7f5dSdrh int addrOutB = 0; /* Address of the output-B subroutine */ 272892b01d53Sdrh int addrEofA; /* Address of the select-A-exhausted subroutine */ 272981cf13ecSdrh int addrEofA_noB; /* Alternate addrEofA if B is uninitialized */ 273092b01d53Sdrh int addrEofB; /* Address of the select-B-exhausted subroutine */ 273192b01d53Sdrh int addrAltB; /* Address of the A<B subroutine */ 273292b01d53Sdrh int addrAeqB; /* Address of the A==B subroutine */ 273392b01d53Sdrh int addrAgtB; /* Address of the A>B subroutine */ 273492b01d53Sdrh int regLimitA; /* Limit register for select-A */ 273592b01d53Sdrh int regLimitB; /* Limit register for select-A */ 27360acb7e48Sdrh int regPrev; /* A range of registers to hold previous output */ 273792b01d53Sdrh int savedLimit; /* Saved value of p->iLimit */ 273892b01d53Sdrh int savedOffset; /* Saved value of p->iOffset */ 273992b01d53Sdrh int labelCmpr; /* Label for the start of the merge algorithm */ 274092b01d53Sdrh int labelEnd; /* Label for the end of the overall SELECT stmt */ 27410acb7e48Sdrh int j1; /* Jump instructions that get retargetted */ 274292b01d53Sdrh int op; /* One of TK_ALL, TK_UNION, TK_EXCEPT, TK_INTERSECT */ 274396067816Sdrh KeyInfo *pKeyDup = 0; /* Comparison information for duplicate removal */ 27440acb7e48Sdrh KeyInfo *pKeyMerge; /* Comparison information for merging rows */ 27450acb7e48Sdrh sqlite3 *db; /* Database connection */ 27460acb7e48Sdrh ExprList *pOrderBy; /* The ORDER BY clause */ 27470acb7e48Sdrh int nOrderBy; /* Number of terms in the ORDER BY clause */ 27480acb7e48Sdrh int *aPermute; /* Mapping from ORDER BY terms to result set columns */ 27497f61e92cSdan #ifndef SQLITE_OMIT_EXPLAIN 27507f61e92cSdan int iSub1; /* EQP id of left-hand query */ 27517f61e92cSdan int iSub2; /* EQP id of right-hand query */ 27527f61e92cSdan #endif 2753b21e7c70Sdrh 275492b01d53Sdrh assert( p->pOrderBy!=0 ); 275596067816Sdrh assert( pKeyDup==0 ); /* "Managed" code needs this. Ticket #3382. */ 27560acb7e48Sdrh db = pParse->db; 275792b01d53Sdrh v = pParse->pVdbe; 2758ccfcbceaSdrh assert( v!=0 ); /* Already thrown the error if VDBE alloc failed */ 275992b01d53Sdrh labelEnd = sqlite3VdbeMakeLabel(v); 276092b01d53Sdrh labelCmpr = sqlite3VdbeMakeLabel(v); 27610acb7e48Sdrh 2762b21e7c70Sdrh 276392b01d53Sdrh /* Patch up the ORDER BY clause 276492b01d53Sdrh */ 276592b01d53Sdrh op = p->op; 2766b21e7c70Sdrh pPrior = p->pPrior; 276792b01d53Sdrh assert( pPrior->pOrderBy==0 ); 27680acb7e48Sdrh pOrderBy = p->pOrderBy; 276993a960a0Sdrh assert( pOrderBy ); 27700acb7e48Sdrh nOrderBy = pOrderBy->nExpr; 277193a960a0Sdrh 27720acb7e48Sdrh /* For operators other than UNION ALL we have to make sure that 27730acb7e48Sdrh ** the ORDER BY clause covers every term of the result set. Add 27740acb7e48Sdrh ** terms to the ORDER BY clause as necessary. 27750acb7e48Sdrh */ 27760acb7e48Sdrh if( op!=TK_ALL ){ 27770acb7e48Sdrh for(i=1; db->mallocFailed==0 && i<=p->pEList->nExpr; i++){ 27787d10d5a6Sdrh struct ExprList_item *pItem; 27797d10d5a6Sdrh for(j=0, pItem=pOrderBy->a; j<nOrderBy; j++, pItem++){ 2780c2acc4e4Sdrh assert( pItem->u.x.iOrderByCol>0 ); 2781c2acc4e4Sdrh if( pItem->u.x.iOrderByCol==i ) break; 27820acb7e48Sdrh } 27830acb7e48Sdrh if( j==nOrderBy ){ 2784b7916a78Sdrh Expr *pNew = sqlite3Expr(db, TK_INTEGER, 0); 27850acb7e48Sdrh if( pNew==0 ) return SQLITE_NOMEM; 27860acb7e48Sdrh pNew->flags |= EP_IntValue; 278733e619fcSdrh pNew->u.iValue = i; 2788b7916a78Sdrh pOrderBy = sqlite3ExprListAppend(pParse, pOrderBy, pNew); 2789c2acc4e4Sdrh if( pOrderBy ) pOrderBy->a[nOrderBy++].u.x.iOrderByCol = (u16)i; 27900acb7e48Sdrh } 27910acb7e48Sdrh } 27920acb7e48Sdrh } 27930acb7e48Sdrh 27940acb7e48Sdrh /* Compute the comparison permutation and keyinfo that is used with 279510c081adSdrh ** the permutation used to determine if the next 27960acb7e48Sdrh ** row of results comes from selectA or selectB. Also add explicit 27970acb7e48Sdrh ** collations to the ORDER BY clause terms so that when the subqueries 27980acb7e48Sdrh ** to the right and the left are evaluated, they use the correct 27990acb7e48Sdrh ** collation. 28000acb7e48Sdrh */ 28010acb7e48Sdrh aPermute = sqlite3DbMallocRaw(db, sizeof(int)*nOrderBy); 28020acb7e48Sdrh if( aPermute ){ 28037d10d5a6Sdrh struct ExprList_item *pItem; 28047d10d5a6Sdrh for(i=0, pItem=pOrderBy->a; i<nOrderBy; i++, pItem++){ 2805c2acc4e4Sdrh assert( pItem->u.x.iOrderByCol>0 2806c2acc4e4Sdrh && pItem->u.x.iOrderByCol<=p->pEList->nExpr ); 2807c2acc4e4Sdrh aPermute[i] = pItem->u.x.iOrderByCol - 1; 28080acb7e48Sdrh } 280953bed45eSdan pKeyMerge = multiSelectOrderByKeyInfo(pParse, p, 1); 28100acb7e48Sdrh }else{ 28110acb7e48Sdrh pKeyMerge = 0; 28120acb7e48Sdrh } 28130acb7e48Sdrh 28140acb7e48Sdrh /* Reattach the ORDER BY clause to the query. 28150acb7e48Sdrh */ 28160acb7e48Sdrh p->pOrderBy = pOrderBy; 28176ab3a2ecSdanielk1977 pPrior->pOrderBy = sqlite3ExprListDup(pParse->db, pOrderBy, 0); 28180acb7e48Sdrh 28190acb7e48Sdrh /* Allocate a range of temporary registers and the KeyInfo needed 28200acb7e48Sdrh ** for the logic that removes duplicate result rows when the 28210acb7e48Sdrh ** operator is UNION, EXCEPT, or INTERSECT (but not UNION ALL). 28220acb7e48Sdrh */ 28230acb7e48Sdrh if( op==TK_ALL ){ 28240acb7e48Sdrh regPrev = 0; 28250acb7e48Sdrh }else{ 28260acb7e48Sdrh int nExpr = p->pEList->nExpr; 28271c0dc825Sdrh assert( nOrderBy>=nExpr || db->mallocFailed ); 2828c8ac0d16Sdrh regPrev = pParse->nMem+1; 2829c8ac0d16Sdrh pParse->nMem += nExpr+1; 28300acb7e48Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 0, regPrev); 2831ad124329Sdrh pKeyDup = sqlite3KeyInfoAlloc(db, nExpr, 1); 28320acb7e48Sdrh if( pKeyDup ){ 28332ec2fb22Sdrh assert( sqlite3KeyInfoIsWriteable(pKeyDup) ); 28340acb7e48Sdrh for(i=0; i<nExpr; i++){ 28350acb7e48Sdrh pKeyDup->aColl[i] = multiSelectCollSeq(pParse, p, i); 28360acb7e48Sdrh pKeyDup->aSortOrder[i] = 0; 28370acb7e48Sdrh } 28380acb7e48Sdrh } 28390acb7e48Sdrh } 284092b01d53Sdrh 284192b01d53Sdrh /* Separate the left and the right query from one another 284292b01d53Sdrh */ 284392b01d53Sdrh p->pPrior = 0; 2844d227a291Sdrh pPrior->pNext = 0; 28457d10d5a6Sdrh sqlite3ResolveOrderGroupBy(pParse, p, p->pOrderBy, "ORDER"); 28460acb7e48Sdrh if( pPrior->pPrior==0 ){ 28477d10d5a6Sdrh sqlite3ResolveOrderGroupBy(pParse, pPrior, pPrior->pOrderBy, "ORDER"); 28480acb7e48Sdrh } 284992b01d53Sdrh 285092b01d53Sdrh /* Compute the limit registers */ 285192b01d53Sdrh computeLimitRegisters(pParse, p, labelEnd); 28520acb7e48Sdrh if( p->iLimit && op==TK_ALL ){ 285392b01d53Sdrh regLimitA = ++pParse->nMem; 285492b01d53Sdrh regLimitB = ++pParse->nMem; 285592b01d53Sdrh sqlite3VdbeAddOp2(v, OP_Copy, p->iOffset ? p->iOffset+1 : p->iLimit, 285692b01d53Sdrh regLimitA); 285792b01d53Sdrh sqlite3VdbeAddOp2(v, OP_Copy, regLimitA, regLimitB); 285892b01d53Sdrh }else{ 285992b01d53Sdrh regLimitA = regLimitB = 0; 286092b01d53Sdrh } 2861633e6d57Sdrh sqlite3ExprDelete(db, p->pLimit); 28620acb7e48Sdrh p->pLimit = 0; 2863633e6d57Sdrh sqlite3ExprDelete(db, p->pOffset); 28640acb7e48Sdrh p->pOffset = 0; 286592b01d53Sdrh 2866b21e7c70Sdrh regAddrA = ++pParse->nMem; 2867b21e7c70Sdrh regAddrB = ++pParse->nMem; 2868b21e7c70Sdrh regOutA = ++pParse->nMem; 2869b21e7c70Sdrh regOutB = ++pParse->nMem; 2870b21e7c70Sdrh sqlite3SelectDestInit(&destA, SRT_Coroutine, regAddrA); 2871b21e7c70Sdrh sqlite3SelectDestInit(&destB, SRT_Coroutine, regAddrB); 2872b21e7c70Sdrh 287392b01d53Sdrh /* Generate a coroutine to evaluate the SELECT statement to the 28740acb7e48Sdrh ** left of the compound operator - the "A" select. 28750acb7e48Sdrh */ 2876ed71a839Sdrh addrSelectA = sqlite3VdbeCurrentAddr(v) + 1; 2877ed71a839Sdrh j1 = sqlite3VdbeAddOp3(v, OP_InitCoroutine, regAddrA, 0, addrSelectA); 2878ed71a839Sdrh VdbeComment((v, "left SELECT")); 287992b01d53Sdrh pPrior->iLimit = regLimitA; 28807f61e92cSdan explainSetInteger(iSub1, pParse->iNextSelectId); 28817d10d5a6Sdrh sqlite3Select(pParse, pPrior, &destA); 288281cf13ecSdrh sqlite3VdbeAddOp1(v, OP_EndCoroutine, regAddrA); 2883ed71a839Sdrh sqlite3VdbeJumpHere(v, j1); 2884b21e7c70Sdrh 288592b01d53Sdrh /* Generate a coroutine to evaluate the SELECT statement on 288692b01d53Sdrh ** the right - the "B" select 288792b01d53Sdrh */ 2888ed71a839Sdrh addrSelectB = sqlite3VdbeCurrentAddr(v) + 1; 2889ed71a839Sdrh j1 = sqlite3VdbeAddOp3(v, OP_InitCoroutine, regAddrB, 0, addrSelectB); 2890ed71a839Sdrh VdbeComment((v, "right SELECT")); 289192b01d53Sdrh savedLimit = p->iLimit; 289292b01d53Sdrh savedOffset = p->iOffset; 289392b01d53Sdrh p->iLimit = regLimitB; 289492b01d53Sdrh p->iOffset = 0; 28957f61e92cSdan explainSetInteger(iSub2, pParse->iNextSelectId); 28967d10d5a6Sdrh sqlite3Select(pParse, p, &destB); 289792b01d53Sdrh p->iLimit = savedLimit; 289892b01d53Sdrh p->iOffset = savedOffset; 289981cf13ecSdrh sqlite3VdbeAddOp1(v, OP_EndCoroutine, regAddrB); 2900b21e7c70Sdrh 290192b01d53Sdrh /* Generate a subroutine that outputs the current row of the A 29020acb7e48Sdrh ** select as the next output row of the compound select. 290392b01d53Sdrh */ 2904b21e7c70Sdrh VdbeNoopComment((v, "Output routine for A")); 29050acb7e48Sdrh addrOutA = generateOutputSubroutine(pParse, 29060acb7e48Sdrh p, &destA, pDest, regOutA, 29072ec2fb22Sdrh regPrev, pKeyDup, labelEnd); 2908b21e7c70Sdrh 290992b01d53Sdrh /* Generate a subroutine that outputs the current row of the B 29100acb7e48Sdrh ** select as the next output row of the compound select. 291192b01d53Sdrh */ 29120acb7e48Sdrh if( op==TK_ALL || op==TK_UNION ){ 2913b21e7c70Sdrh VdbeNoopComment((v, "Output routine for B")); 29140acb7e48Sdrh addrOutB = generateOutputSubroutine(pParse, 29150acb7e48Sdrh p, &destB, pDest, regOutB, 29162ec2fb22Sdrh regPrev, pKeyDup, labelEnd); 29170acb7e48Sdrh } 29182ec2fb22Sdrh sqlite3KeyInfoUnref(pKeyDup); 2919b21e7c70Sdrh 292092b01d53Sdrh /* Generate a subroutine to run when the results from select A 292192b01d53Sdrh ** are exhausted and only data in select B remains. 292292b01d53Sdrh */ 292392b01d53Sdrh if( op==TK_EXCEPT || op==TK_INTERSECT ){ 292481cf13ecSdrh addrEofA_noB = addrEofA = labelEnd; 292592b01d53Sdrh }else{ 292681cf13ecSdrh VdbeNoopComment((v, "eof-A subroutine")); 292781cf13ecSdrh addrEofA = sqlite3VdbeAddOp2(v, OP_Gosub, regOutB, addrOutB); 292881cf13ecSdrh addrEofA_noB = sqlite3VdbeAddOp2(v, OP_Yield, regAddrB, labelEnd); 2929688852abSdrh VdbeCoverage(v); 29300acb7e48Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, addrEofA); 293195aa47b1Sdrh p->nSelectRow += pPrior->nSelectRow; 2932b21e7c70Sdrh } 2933b21e7c70Sdrh 293492b01d53Sdrh /* Generate a subroutine to run when the results from select B 293592b01d53Sdrh ** are exhausted and only data in select A remains. 293692b01d53Sdrh */ 2937b21e7c70Sdrh if( op==TK_INTERSECT ){ 293892b01d53Sdrh addrEofB = addrEofA; 293995aa47b1Sdrh if( p->nSelectRow > pPrior->nSelectRow ) p->nSelectRow = pPrior->nSelectRow; 2940b21e7c70Sdrh }else{ 294192b01d53Sdrh VdbeNoopComment((v, "eof-B subroutine")); 294281cf13ecSdrh addrEofB = sqlite3VdbeAddOp2(v, OP_Gosub, regOutA, addrOutA); 2943688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrA, labelEnd); VdbeCoverage(v); 29440acb7e48Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, addrEofB); 2945b21e7c70Sdrh } 2946b21e7c70Sdrh 294792b01d53Sdrh /* Generate code to handle the case of A<B 294892b01d53Sdrh */ 2949b21e7c70Sdrh VdbeNoopComment((v, "A-lt-B subroutine")); 29500acb7e48Sdrh addrAltB = sqlite3VdbeAddOp2(v, OP_Gosub, regOutA, addrOutA); 2951688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrA, addrEofA); VdbeCoverage(v); 295292b01d53Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, labelCmpr); 2953b21e7c70Sdrh 295492b01d53Sdrh /* Generate code to handle the case of A==B 295592b01d53Sdrh */ 2956b21e7c70Sdrh if( op==TK_ALL ){ 2957b21e7c70Sdrh addrAeqB = addrAltB; 29580acb7e48Sdrh }else if( op==TK_INTERSECT ){ 29590acb7e48Sdrh addrAeqB = addrAltB; 29600acb7e48Sdrh addrAltB++; 296192b01d53Sdrh }else{ 2962b21e7c70Sdrh VdbeNoopComment((v, "A-eq-B subroutine")); 29630acb7e48Sdrh addrAeqB = 2964688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrA, addrEofA); VdbeCoverage(v); 296592b01d53Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, labelCmpr); 296692b01d53Sdrh } 2967b21e7c70Sdrh 296892b01d53Sdrh /* Generate code to handle the case of A>B 296992b01d53Sdrh */ 2970b21e7c70Sdrh VdbeNoopComment((v, "A-gt-B subroutine")); 2971b21e7c70Sdrh addrAgtB = sqlite3VdbeCurrentAddr(v); 2972b21e7c70Sdrh if( op==TK_ALL || op==TK_UNION ){ 2973b21e7c70Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, regOutB, addrOutB); 297492b01d53Sdrh } 2975688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrB, addrEofB); VdbeCoverage(v); 297692b01d53Sdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, labelCmpr); 2977b21e7c70Sdrh 297892b01d53Sdrh /* This code runs once to initialize everything. 297992b01d53Sdrh */ 2980b21e7c70Sdrh sqlite3VdbeJumpHere(v, j1); 2981688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrA, addrEofA_noB); VdbeCoverage(v); 2982688852abSdrh sqlite3VdbeAddOp2(v, OP_Yield, regAddrB, addrEofB); VdbeCoverage(v); 298392b01d53Sdrh 298492b01d53Sdrh /* Implement the main merge loop 298592b01d53Sdrh */ 298692b01d53Sdrh sqlite3VdbeResolveLabel(v, labelCmpr); 29870acb7e48Sdrh sqlite3VdbeAddOp4(v, OP_Permutation, 0, 0, 0, (char*)aPermute, P4_INTARRAY); 29882b596da8Sdrh sqlite3VdbeAddOp4(v, OP_Compare, destA.iSdst, destB.iSdst, nOrderBy, 29892ec2fb22Sdrh (char*)pKeyMerge, P4_KEYINFO); 2990953f7611Sdrh sqlite3VdbeChangeP5(v, OPFLAG_PERMUTE); 2991688852abSdrh sqlite3VdbeAddOp3(v, OP_Jump, addrAltB, addrAeqB, addrAgtB); VdbeCoverage(v); 299292b01d53Sdrh 299392b01d53Sdrh /* Jump to the this point in order to terminate the query. 299492b01d53Sdrh */ 2995b21e7c70Sdrh sqlite3VdbeResolveLabel(v, labelEnd); 2996b21e7c70Sdrh 299792b01d53Sdrh /* Set the number of output columns 299892b01d53Sdrh */ 29997d10d5a6Sdrh if( pDest->eDest==SRT_Output ){ 30000acb7e48Sdrh Select *pFirst = pPrior; 300192b01d53Sdrh while( pFirst->pPrior ) pFirst = pFirst->pPrior; 300292b01d53Sdrh generateColumnNames(pParse, 0, pFirst->pEList); 3003b21e7c70Sdrh } 300492b01d53Sdrh 30050acb7e48Sdrh /* Reassembly the compound query so that it will be freed correctly 30060acb7e48Sdrh ** by the calling function */ 30075e7ad508Sdanielk1977 if( p->pPrior ){ 3008633e6d57Sdrh sqlite3SelectDelete(db, p->pPrior); 30095e7ad508Sdanielk1977 } 30100acb7e48Sdrh p->pPrior = pPrior; 3011d227a291Sdrh pPrior->pNext = p; 301292b01d53Sdrh 301392b01d53Sdrh /*** TBD: Insert subroutine calls to close cursors on incomplete 301492b01d53Sdrh **** subqueries ****/ 30157f61e92cSdan explainComposite(pParse, p->op, iSub1, iSub2, 0); 301692b01d53Sdrh return SQLITE_OK; 301792b01d53Sdrh } 3018de3e41e3Sdanielk1977 #endif 3019b21e7c70Sdrh 30203514b6f7Sshane #if !defined(SQLITE_OMIT_SUBQUERY) || !defined(SQLITE_OMIT_VIEW) 302117435752Sdrh /* Forward Declarations */ 302217435752Sdrh static void substExprList(sqlite3*, ExprList*, int, ExprList*); 302317435752Sdrh static void substSelect(sqlite3*, Select *, int, ExprList *); 302417435752Sdrh 30252282792aSdrh /* 3026832508b7Sdrh ** Scan through the expression pExpr. Replace every reference to 30276a3ea0e6Sdrh ** a column in table number iTable with a copy of the iColumn-th 302884e59207Sdrh ** entry in pEList. (But leave references to the ROWID column 30296a3ea0e6Sdrh ** unchanged.) 3030832508b7Sdrh ** 3031832508b7Sdrh ** This routine is part of the flattening procedure. A subquery 3032832508b7Sdrh ** whose result set is defined by pEList appears as entry in the 3033832508b7Sdrh ** FROM clause of a SELECT such that the VDBE cursor assigned to that 3034832508b7Sdrh ** FORM clause entry is iTable. This routine make the necessary 3035832508b7Sdrh ** changes to pExpr so that it refers directly to the source table 3036832508b7Sdrh ** of the subquery rather the result set of the subquery. 3037832508b7Sdrh */ 3038b7916a78Sdrh static Expr *substExpr( 303917435752Sdrh sqlite3 *db, /* Report malloc errors to this connection */ 304017435752Sdrh Expr *pExpr, /* Expr in which substitution occurs */ 304117435752Sdrh int iTable, /* Table to be substituted */ 304217435752Sdrh ExprList *pEList /* Substitute expressions */ 304317435752Sdrh ){ 3044b7916a78Sdrh if( pExpr==0 ) return 0; 304550350a15Sdrh if( pExpr->op==TK_COLUMN && pExpr->iTable==iTable ){ 304650350a15Sdrh if( pExpr->iColumn<0 ){ 304750350a15Sdrh pExpr->op = TK_NULL; 304850350a15Sdrh }else{ 3049832508b7Sdrh Expr *pNew; 305084e59207Sdrh assert( pEList!=0 && pExpr->iColumn<pEList->nExpr ); 30516ab3a2ecSdanielk1977 assert( pExpr->pLeft==0 && pExpr->pRight==0 ); 3052b7916a78Sdrh pNew = sqlite3ExprDup(db, pEList->a[pExpr->iColumn].pExpr, 0); 3053b7916a78Sdrh sqlite3ExprDelete(db, pExpr); 3054b7916a78Sdrh pExpr = pNew; 305550350a15Sdrh } 3056832508b7Sdrh }else{ 3057b7916a78Sdrh pExpr->pLeft = substExpr(db, pExpr->pLeft, iTable, pEList); 3058b7916a78Sdrh pExpr->pRight = substExpr(db, pExpr->pRight, iTable, pEList); 30596ab3a2ecSdanielk1977 if( ExprHasProperty(pExpr, EP_xIsSelect) ){ 30606ab3a2ecSdanielk1977 substSelect(db, pExpr->x.pSelect, iTable, pEList); 30616ab3a2ecSdanielk1977 }else{ 30626ab3a2ecSdanielk1977 substExprList(db, pExpr->x.pList, iTable, pEList); 30636ab3a2ecSdanielk1977 } 3064832508b7Sdrh } 3065b7916a78Sdrh return pExpr; 3066832508b7Sdrh } 306717435752Sdrh static void substExprList( 306817435752Sdrh sqlite3 *db, /* Report malloc errors here */ 306917435752Sdrh ExprList *pList, /* List to scan and in which to make substitutes */ 307017435752Sdrh int iTable, /* Table to be substituted */ 307117435752Sdrh ExprList *pEList /* Substitute values */ 307217435752Sdrh ){ 3073832508b7Sdrh int i; 3074832508b7Sdrh if( pList==0 ) return; 3075832508b7Sdrh for(i=0; i<pList->nExpr; i++){ 3076b7916a78Sdrh pList->a[i].pExpr = substExpr(db, pList->a[i].pExpr, iTable, pEList); 3077832508b7Sdrh } 3078832508b7Sdrh } 307917435752Sdrh static void substSelect( 308017435752Sdrh sqlite3 *db, /* Report malloc errors here */ 308117435752Sdrh Select *p, /* SELECT statement in which to make substitutions */ 308217435752Sdrh int iTable, /* Table to be replaced */ 308317435752Sdrh ExprList *pEList /* Substitute values */ 308417435752Sdrh ){ 3085588a9a1aSdrh SrcList *pSrc; 3086588a9a1aSdrh struct SrcList_item *pItem; 3087588a9a1aSdrh int i; 3088b3bce662Sdanielk1977 if( !p ) return; 308917435752Sdrh substExprList(db, p->pEList, iTable, pEList); 309017435752Sdrh substExprList(db, p->pGroupBy, iTable, pEList); 309117435752Sdrh substExprList(db, p->pOrderBy, iTable, pEList); 3092b7916a78Sdrh p->pHaving = substExpr(db, p->pHaving, iTable, pEList); 3093b7916a78Sdrh p->pWhere = substExpr(db, p->pWhere, iTable, pEList); 309417435752Sdrh substSelect(db, p->pPrior, iTable, pEList); 3095588a9a1aSdrh pSrc = p->pSrc; 3096e2f02bacSdrh assert( pSrc ); /* Even for (SELECT 1) we have: pSrc!=0 but pSrc->nSrc==0 */ 3097e2f02bacSdrh if( ALWAYS(pSrc) ){ 3098588a9a1aSdrh for(i=pSrc->nSrc, pItem=pSrc->a; i>0; i--, pItem++){ 3099588a9a1aSdrh substSelect(db, pItem->pSelect, iTable, pEList); 3100588a9a1aSdrh } 3101588a9a1aSdrh } 3102b3bce662Sdanielk1977 } 31033514b6f7Sshane #endif /* !defined(SQLITE_OMIT_SUBQUERY) || !defined(SQLITE_OMIT_VIEW) */ 3104832508b7Sdrh 31053514b6f7Sshane #if !defined(SQLITE_OMIT_SUBQUERY) || !defined(SQLITE_OMIT_VIEW) 3106832508b7Sdrh /* 3107630d296cSdrh ** This routine attempts to flatten subqueries as a performance optimization. 3108630d296cSdrh ** This routine returns 1 if it makes changes and 0 if no flattening occurs. 31091350b030Sdrh ** 31101350b030Sdrh ** To understand the concept of flattening, consider the following 31111350b030Sdrh ** query: 31121350b030Sdrh ** 31131350b030Sdrh ** SELECT a FROM (SELECT x+y AS a FROM t1 WHERE z<100) WHERE a>5 31141350b030Sdrh ** 31151350b030Sdrh ** The default way of implementing this query is to execute the 31161350b030Sdrh ** subquery first and store the results in a temporary table, then 31171350b030Sdrh ** run the outer query on that temporary table. This requires two 31181350b030Sdrh ** passes over the data. Furthermore, because the temporary table 31191350b030Sdrh ** has no indices, the WHERE clause on the outer query cannot be 3120832508b7Sdrh ** optimized. 31211350b030Sdrh ** 3122832508b7Sdrh ** This routine attempts to rewrite queries such as the above into 31231350b030Sdrh ** a single flat select, like this: 31241350b030Sdrh ** 31251350b030Sdrh ** SELECT x+y AS a FROM t1 WHERE z<100 AND a>5 31261350b030Sdrh ** 312760ec914cSpeter.d.reid ** The code generated for this simplification gives the same result 3128832508b7Sdrh ** but only has to scan the data once. And because indices might 3129832508b7Sdrh ** exist on the table t1, a complete scan of the data might be 3130832508b7Sdrh ** avoided. 31311350b030Sdrh ** 3132832508b7Sdrh ** Flattening is only attempted if all of the following are true: 31331350b030Sdrh ** 3134832508b7Sdrh ** (1) The subquery and the outer query do not both use aggregates. 31351350b030Sdrh ** 3136832508b7Sdrh ** (2) The subquery is not an aggregate or the outer query is not a join. 3137832508b7Sdrh ** 31382b300d5dSdrh ** (3) The subquery is not the right operand of a left outer join 313949ad330dSdan ** (Originally ticket #306. Strengthened by ticket #3300) 3140832508b7Sdrh ** 314149ad330dSdan ** (4) The subquery is not DISTINCT. 3142832508b7Sdrh ** 314349ad330dSdan ** (**) At one point restrictions (4) and (5) defined a subset of DISTINCT 314449ad330dSdan ** sub-queries that were excluded from this optimization. Restriction 314549ad330dSdan ** (4) has since been expanded to exclude all DISTINCT subqueries. 3146832508b7Sdrh ** 3147832508b7Sdrh ** (6) The subquery does not use aggregates or the outer query is not 3148832508b7Sdrh ** DISTINCT. 3149832508b7Sdrh ** 3150630d296cSdrh ** (7) The subquery has a FROM clause. TODO: For subqueries without 3151630d296cSdrh ** A FROM clause, consider adding a FROM close with the special 3152630d296cSdrh ** table sqlite_once that consists of a single row containing a 3153630d296cSdrh ** single NULL. 315408192d5fSdrh ** 3155df199a25Sdrh ** (8) The subquery does not use LIMIT or the outer query is not a join. 3156df199a25Sdrh ** 3157df199a25Sdrh ** (9) The subquery does not use LIMIT or the outer query does not use 3158df199a25Sdrh ** aggregates. 3159df199a25Sdrh ** 31606092d2bcSdrh ** (**) Restriction (10) was removed from the code on 2005-02-05 but we 31616092d2bcSdrh ** accidently carried the comment forward until 2014-09-15. Original 31626092d2bcSdrh ** text: "The subquery does not use aggregates or the outer query does not 31636092d2bcSdrh ** use LIMIT." 3164df199a25Sdrh ** 3165174b6195Sdrh ** (11) The subquery and the outer query do not both have ORDER BY clauses. 3166174b6195Sdrh ** 31677b688edeSdrh ** (**) Not implemented. Subsumed into restriction (3). Was previously 31682b300d5dSdrh ** a separate restriction deriving from ticket #350. 31693fc673e6Sdrh ** 317049ad330dSdan ** (13) The subquery and outer query do not both use LIMIT. 3171ac83963aSdrh ** 317249ad330dSdan ** (14) The subquery does not use OFFSET. 3173ac83963aSdrh ** 3174ad91c6cdSdrh ** (15) The outer query is not part of a compound select or the 3175f3913278Sdrh ** subquery does not have a LIMIT clause. 3176f3913278Sdrh ** (See ticket #2339 and ticket [02a8e81d44]). 3177ad91c6cdSdrh ** 3178c52e355dSdrh ** (16) The outer query is not an aggregate or the subquery does 3179c52e355dSdrh ** not contain ORDER BY. (Ticket #2942) This used to not matter 3180c52e355dSdrh ** until we introduced the group_concat() function. 3181c52e355dSdrh ** 3182f23329a2Sdanielk1977 ** (17) The sub-query is not a compound select, or it is a UNION ALL 31834914cf92Sdanielk1977 ** compound clause made up entirely of non-aggregate queries, and 3184f23329a2Sdanielk1977 ** the parent query: 3185f23329a2Sdanielk1977 ** 3186f23329a2Sdanielk1977 ** * is not itself part of a compound select, 3187f23329a2Sdanielk1977 ** * is not an aggregate or DISTINCT query, and 3188630d296cSdrh ** * is not a join 3189f23329a2Sdanielk1977 ** 31904914cf92Sdanielk1977 ** The parent and sub-query may contain WHERE clauses. Subject to 31914914cf92Sdanielk1977 ** rules (11), (13) and (14), they may also contain ORDER BY, 3192630d296cSdrh ** LIMIT and OFFSET clauses. The subquery cannot use any compound 3193630d296cSdrh ** operator other than UNION ALL because all the other compound 3194630d296cSdrh ** operators have an implied DISTINCT which is disallowed by 3195630d296cSdrh ** restriction (4). 3196f23329a2Sdanielk1977 ** 319767c70142Sdan ** Also, each component of the sub-query must return the same number 319867c70142Sdan ** of result columns. This is actually a requirement for any compound 319967c70142Sdan ** SELECT statement, but all the code here does is make sure that no 320067c70142Sdan ** such (illegal) sub-query is flattened. The caller will detect the 320167c70142Sdan ** syntax error and return a detailed message. 320267c70142Sdan ** 320349fc1f60Sdanielk1977 ** (18) If the sub-query is a compound select, then all terms of the 320449fc1f60Sdanielk1977 ** ORDER by clause of the parent must be simple references to 320549fc1f60Sdanielk1977 ** columns of the sub-query. 320649fc1f60Sdanielk1977 ** 3207229cf702Sdrh ** (19) The subquery does not use LIMIT or the outer query does not 3208229cf702Sdrh ** have a WHERE clause. 3209229cf702Sdrh ** 3210e8902a70Sdrh ** (20) If the sub-query is a compound select, then it must not use 3211e8902a70Sdrh ** an ORDER BY clause. Ticket #3773. We could relax this constraint 3212e8902a70Sdrh ** somewhat by saying that the terms of the ORDER BY clause must 3213630d296cSdrh ** appear as unmodified result columns in the outer query. But we 3214e8902a70Sdrh ** have other optimizations in mind to deal with that case. 3215e8902a70Sdrh ** 3216a91491e5Sshaneh ** (21) The subquery does not use LIMIT or the outer query is not 3217a91491e5Sshaneh ** DISTINCT. (See ticket [752e1646fc]). 3218a91491e5Sshaneh ** 32198290c2adSdan ** (22) The subquery is not a recursive CTE. 32208290c2adSdan ** 32218290c2adSdan ** (23) The parent is not a recursive CTE, or the sub-query is not a 32228290c2adSdan ** compound query. This restriction is because transforming the 32238290c2adSdan ** parent to a compound query confuses the code that handles 32248290c2adSdan ** recursive queries in multiSelect(). 32258290c2adSdan ** 32269588ad95Sdrh ** (24) The subquery is not an aggregate that uses the built-in min() or 32279588ad95Sdrh ** or max() functions. (Without this restriction, a query like: 32289588ad95Sdrh ** "SELECT x FROM (SELECT max(y), x FROM t1)" would not necessarily 32299588ad95Sdrh ** return the value X for which Y was maximal.) 32309588ad95Sdrh ** 32318290c2adSdan ** 3232832508b7Sdrh ** In this routine, the "p" parameter is a pointer to the outer query. 3233832508b7Sdrh ** The subquery is p->pSrc->a[iFrom]. isAgg is true if the outer query 3234832508b7Sdrh ** uses aggregates and subqueryIsAgg is true if the subquery uses aggregates. 3235832508b7Sdrh ** 3236665de47aSdrh ** If flattening is not attempted, this routine is a no-op and returns 0. 3237832508b7Sdrh ** If flattening is attempted this routine returns 1. 3238832508b7Sdrh ** 3239832508b7Sdrh ** All of the expression analysis must occur on both the outer query and 3240832508b7Sdrh ** the subquery before this routine runs. 32411350b030Sdrh */ 32428c74a8caSdrh static int flattenSubquery( 3243524cc21eSdanielk1977 Parse *pParse, /* Parsing context */ 32448c74a8caSdrh Select *p, /* The parent or outer SELECT statement */ 32458c74a8caSdrh int iFrom, /* Index in p->pSrc->a[] of the inner subquery */ 32468c74a8caSdrh int isAgg, /* True if outer SELECT uses aggregate functions */ 32478c74a8caSdrh int subqueryIsAgg /* True if the subquery uses aggregate functions */ 32488c74a8caSdrh ){ 3249524cc21eSdanielk1977 const char *zSavedAuthContext = pParse->zAuthContext; 3250f23329a2Sdanielk1977 Select *pParent; 32510bb28106Sdrh Select *pSub; /* The inner query or "subquery" */ 3252f23329a2Sdanielk1977 Select *pSub1; /* Pointer to the rightmost select in sub-query */ 3253ad3cab52Sdrh SrcList *pSrc; /* The FROM clause of the outer query */ 3254ad3cab52Sdrh SrcList *pSubSrc; /* The FROM clause of the subquery */ 32550bb28106Sdrh ExprList *pList; /* The result set of the outer query */ 32566a3ea0e6Sdrh int iParent; /* VDBE cursor number of the pSub result set temp table */ 325791bb0eedSdrh int i; /* Loop counter */ 325891bb0eedSdrh Expr *pWhere; /* The WHERE clause */ 325991bb0eedSdrh struct SrcList_item *pSubitem; /* The subquery */ 3260524cc21eSdanielk1977 sqlite3 *db = pParse->db; 32611350b030Sdrh 3262832508b7Sdrh /* Check to see if flattening is permitted. Return 0 if not. 3263832508b7Sdrh */ 3264a78c22c4Sdrh assert( p!=0 ); 3265a78c22c4Sdrh assert( p->pPrior==0 ); /* Unable to flatten compound queries */ 32667e5418e4Sdrh if( OptimizationDisabled(db, SQLITE_QueryFlattener) ) return 0; 3267832508b7Sdrh pSrc = p->pSrc; 3268ad3cab52Sdrh assert( pSrc && iFrom>=0 && iFrom<pSrc->nSrc ); 326991bb0eedSdrh pSubitem = &pSrc->a[iFrom]; 327049fc1f60Sdanielk1977 iParent = pSubitem->iCursor; 327191bb0eedSdrh pSub = pSubitem->pSelect; 3272832508b7Sdrh assert( pSub!=0 ); 3273ac83963aSdrh if( isAgg && subqueryIsAgg ) return 0; /* Restriction (1) */ 3274ac83963aSdrh if( subqueryIsAgg && pSrc->nSrc>1 ) return 0; /* Restriction (2) */ 3275832508b7Sdrh pSubSrc = pSub->pSrc; 3276832508b7Sdrh assert( pSubSrc ); 3277ac83963aSdrh /* Prior to version 3.1.2, when LIMIT and OFFSET had to be simple constants, 327860ec914cSpeter.d.reid ** not arbitrary expressions, we allowed some combining of LIMIT and OFFSET 3279ac83963aSdrh ** because they could be computed at compile-time. But when LIMIT and OFFSET 3280ac83963aSdrh ** became arbitrary expressions, we were forced to add restrictions (13) 3281ac83963aSdrh ** and (14). */ 3282ac83963aSdrh if( pSub->pLimit && p->pLimit ) return 0; /* Restriction (13) */ 3283ac83963aSdrh if( pSub->pOffset ) return 0; /* Restriction (14) */ 3284d227a291Sdrh if( (p->selFlags & SF_Compound)!=0 && pSub->pLimit ){ 3285ad91c6cdSdrh return 0; /* Restriction (15) */ 3286ad91c6cdSdrh } 3287ac83963aSdrh if( pSubSrc->nSrc==0 ) return 0; /* Restriction (7) */ 328849ad330dSdan if( pSub->selFlags & SF_Distinct ) return 0; /* Restriction (5) */ 328949ad330dSdan if( pSub->pLimit && (pSrc->nSrc>1 || isAgg) ){ 329049ad330dSdan return 0; /* Restrictions (8)(9) */ 3291df199a25Sdrh } 32927d10d5a6Sdrh if( (p->selFlags & SF_Distinct)!=0 && subqueryIsAgg ){ 32937d10d5a6Sdrh return 0; /* Restriction (6) */ 32947d10d5a6Sdrh } 32957d10d5a6Sdrh if( p->pOrderBy && pSub->pOrderBy ){ 3296ac83963aSdrh return 0; /* Restriction (11) */ 3297ac83963aSdrh } 3298c52e355dSdrh if( isAgg && pSub->pOrderBy ) return 0; /* Restriction (16) */ 3299229cf702Sdrh if( pSub->pLimit && p->pWhere ) return 0; /* Restriction (19) */ 3300a91491e5Sshaneh if( pSub->pLimit && (p->selFlags & SF_Distinct)!=0 ){ 3301a91491e5Sshaneh return 0; /* Restriction (21) */ 3302a91491e5Sshaneh } 33039588ad95Sdrh testcase( pSub->selFlags & SF_Recursive ); 33049588ad95Sdrh testcase( pSub->selFlags & SF_MinMaxAgg ); 33059588ad95Sdrh if( pSub->selFlags & (SF_Recursive|SF_MinMaxAgg) ){ 33069588ad95Sdrh return 0; /* Restrictions (22) and (24) */ 33079588ad95Sdrh } 33089588ad95Sdrh if( (p->selFlags & SF_Recursive) && pSub->pPrior ){ 33099588ad95Sdrh return 0; /* Restriction (23) */ 33109588ad95Sdrh } 3311832508b7Sdrh 33122b300d5dSdrh /* OBSOLETE COMMENT 1: 33132b300d5dSdrh ** Restriction 3: If the subquery is a join, make sure the subquery is 33148af4d3acSdrh ** not used as the right operand of an outer join. Examples of why this 33158af4d3acSdrh ** is not allowed: 33168af4d3acSdrh ** 33178af4d3acSdrh ** t1 LEFT OUTER JOIN (t2 JOIN t3) 33188af4d3acSdrh ** 33198af4d3acSdrh ** If we flatten the above, we would get 33208af4d3acSdrh ** 33218af4d3acSdrh ** (t1 LEFT OUTER JOIN t2) JOIN t3 33228af4d3acSdrh ** 33238af4d3acSdrh ** which is not at all the same thing. 33242b300d5dSdrh ** 33252b300d5dSdrh ** OBSOLETE COMMENT 2: 33262b300d5dSdrh ** Restriction 12: If the subquery is the right operand of a left outer 33273fc673e6Sdrh ** join, make sure the subquery has no WHERE clause. 33283fc673e6Sdrh ** An examples of why this is not allowed: 33293fc673e6Sdrh ** 33303fc673e6Sdrh ** t1 LEFT OUTER JOIN (SELECT * FROM t2 WHERE t2.x>0) 33313fc673e6Sdrh ** 33323fc673e6Sdrh ** If we flatten the above, we would get 33333fc673e6Sdrh ** 33343fc673e6Sdrh ** (t1 LEFT OUTER JOIN t2) WHERE t2.x>0 33353fc673e6Sdrh ** 33363fc673e6Sdrh ** But the t2.x>0 test will always fail on a NULL row of t2, which 33373fc673e6Sdrh ** effectively converts the OUTER JOIN into an INNER JOIN. 33382b300d5dSdrh ** 33392b300d5dSdrh ** THIS OVERRIDES OBSOLETE COMMENTS 1 AND 2 ABOVE: 33402b300d5dSdrh ** Ticket #3300 shows that flattening the right term of a LEFT JOIN 33412b300d5dSdrh ** is fraught with danger. Best to avoid the whole thing. If the 33422b300d5dSdrh ** subquery is the right term of a LEFT JOIN, then do not flatten. 33433fc673e6Sdrh */ 33442b300d5dSdrh if( (pSubitem->jointype & JT_OUTER)!=0 ){ 33453fc673e6Sdrh return 0; 33463fc673e6Sdrh } 33473fc673e6Sdrh 3348f23329a2Sdanielk1977 /* Restriction 17: If the sub-query is a compound SELECT, then it must 3349f23329a2Sdanielk1977 ** use only the UNION ALL operator. And none of the simple select queries 3350f23329a2Sdanielk1977 ** that make up the compound SELECT are allowed to be aggregate or distinct 3351f23329a2Sdanielk1977 ** queries. 3352f23329a2Sdanielk1977 */ 3353f23329a2Sdanielk1977 if( pSub->pPrior ){ 3354e8902a70Sdrh if( pSub->pOrderBy ){ 3355e8902a70Sdrh return 0; /* Restriction 20 */ 3356e8902a70Sdrh } 3357e2f02bacSdrh if( isAgg || (p->selFlags & SF_Distinct)!=0 || pSrc->nSrc!=1 ){ 3358f23329a2Sdanielk1977 return 0; 3359f23329a2Sdanielk1977 } 3360f23329a2Sdanielk1977 for(pSub1=pSub; pSub1; pSub1=pSub1->pPrior){ 3361ccfcbceaSdrh testcase( (pSub1->selFlags & (SF_Distinct|SF_Aggregate))==SF_Distinct ); 3362ccfcbceaSdrh testcase( (pSub1->selFlags & (SF_Distinct|SF_Aggregate))==SF_Aggregate ); 33634b3ac73cSdrh assert( pSub->pSrc!=0 ); 33647d10d5a6Sdrh if( (pSub1->selFlags & (SF_Distinct|SF_Aggregate))!=0 336580b3c548Sdanielk1977 || (pSub1->pPrior && pSub1->op!=TK_ALL) 33664b3ac73cSdrh || pSub1->pSrc->nSrc<1 336767c70142Sdan || pSub->pEList->nExpr!=pSub1->pEList->nExpr 336880b3c548Sdanielk1977 ){ 3369f23329a2Sdanielk1977 return 0; 3370f23329a2Sdanielk1977 } 33714b3ac73cSdrh testcase( pSub1->pSrc->nSrc>1 ); 3372f23329a2Sdanielk1977 } 337349fc1f60Sdanielk1977 337449fc1f60Sdanielk1977 /* Restriction 18. */ 337549fc1f60Sdanielk1977 if( p->pOrderBy ){ 337649fc1f60Sdanielk1977 int ii; 337749fc1f60Sdanielk1977 for(ii=0; ii<p->pOrderBy->nExpr; ii++){ 3378c2acc4e4Sdrh if( p->pOrderBy->a[ii].u.x.iOrderByCol==0 ) return 0; 337949fc1f60Sdanielk1977 } 338049fc1f60Sdanielk1977 } 3381f23329a2Sdanielk1977 } 3382f23329a2Sdanielk1977 33837d10d5a6Sdrh /***** If we reach this point, flattening is permitted. *****/ 3384eb9b884cSdrh SELECTTRACE(1,pParse,p,("flatten %s.%p from term %d\n", 3385eb9b884cSdrh pSub->zSelName, pSub, iFrom)); 33867d10d5a6Sdrh 33877d10d5a6Sdrh /* Authorize the subquery */ 3388524cc21eSdanielk1977 pParse->zAuthContext = pSubitem->zName; 3389a2acb0d7Sdrh TESTONLY(i =) sqlite3AuthCheck(pParse, SQLITE_SELECT, 0, 0, 0); 3390a2acb0d7Sdrh testcase( i==SQLITE_DENY ); 3391524cc21eSdanielk1977 pParse->zAuthContext = zSavedAuthContext; 3392524cc21eSdanielk1977 33937d10d5a6Sdrh /* If the sub-query is a compound SELECT statement, then (by restrictions 33947d10d5a6Sdrh ** 17 and 18 above) it must be a UNION ALL and the parent query must 33957d10d5a6Sdrh ** be of the form: 3396f23329a2Sdanielk1977 ** 3397f23329a2Sdanielk1977 ** SELECT <expr-list> FROM (<sub-query>) <where-clause> 3398f23329a2Sdanielk1977 ** 3399f23329a2Sdanielk1977 ** followed by any ORDER BY, LIMIT and/or OFFSET clauses. This block 3400a78c22c4Sdrh ** creates N-1 copies of the parent query without any ORDER BY, LIMIT or 3401f23329a2Sdanielk1977 ** OFFSET clauses and joins them to the left-hand-side of the original 3402f23329a2Sdanielk1977 ** using UNION ALL operators. In this case N is the number of simple 3403f23329a2Sdanielk1977 ** select statements in the compound sub-query. 3404a78c22c4Sdrh ** 3405a78c22c4Sdrh ** Example: 3406a78c22c4Sdrh ** 3407a78c22c4Sdrh ** SELECT a+1 FROM ( 3408a78c22c4Sdrh ** SELECT x FROM tab 3409a78c22c4Sdrh ** UNION ALL 3410a78c22c4Sdrh ** SELECT y FROM tab 3411a78c22c4Sdrh ** UNION ALL 3412a78c22c4Sdrh ** SELECT abs(z*2) FROM tab2 3413a78c22c4Sdrh ** ) WHERE a!=5 ORDER BY 1 3414a78c22c4Sdrh ** 3415a78c22c4Sdrh ** Transformed into: 3416a78c22c4Sdrh ** 3417a78c22c4Sdrh ** SELECT x+1 FROM tab WHERE x+1!=5 3418a78c22c4Sdrh ** UNION ALL 3419a78c22c4Sdrh ** SELECT y+1 FROM tab WHERE y+1!=5 3420a78c22c4Sdrh ** UNION ALL 3421a78c22c4Sdrh ** SELECT abs(z*2)+1 FROM tab2 WHERE abs(z*2)+1!=5 3422a78c22c4Sdrh ** ORDER BY 1 3423a78c22c4Sdrh ** 3424a78c22c4Sdrh ** We call this the "compound-subquery flattening". 3425f23329a2Sdanielk1977 */ 3426f23329a2Sdanielk1977 for(pSub=pSub->pPrior; pSub; pSub=pSub->pPrior){ 3427f23329a2Sdanielk1977 Select *pNew; 3428f23329a2Sdanielk1977 ExprList *pOrderBy = p->pOrderBy; 34294b86ef1dSdanielk1977 Expr *pLimit = p->pLimit; 3430547180baSdrh Expr *pOffset = p->pOffset; 3431f23329a2Sdanielk1977 Select *pPrior = p->pPrior; 3432f23329a2Sdanielk1977 p->pOrderBy = 0; 3433f23329a2Sdanielk1977 p->pSrc = 0; 3434f23329a2Sdanielk1977 p->pPrior = 0; 34354b86ef1dSdanielk1977 p->pLimit = 0; 3436547180baSdrh p->pOffset = 0; 34376ab3a2ecSdanielk1977 pNew = sqlite3SelectDup(db, p, 0); 3438eb9b884cSdrh sqlite3SelectSetName(pNew, pSub->zSelName); 3439547180baSdrh p->pOffset = pOffset; 34404b86ef1dSdanielk1977 p->pLimit = pLimit; 3441a78c22c4Sdrh p->pOrderBy = pOrderBy; 3442a78c22c4Sdrh p->pSrc = pSrc; 3443a78c22c4Sdrh p->op = TK_ALL; 3444a78c22c4Sdrh if( pNew==0 ){ 3445d227a291Sdrh p->pPrior = pPrior; 3446a78c22c4Sdrh }else{ 3447a78c22c4Sdrh pNew->pPrior = pPrior; 3448d227a291Sdrh if( pPrior ) pPrior->pNext = pNew; 3449d227a291Sdrh pNew->pNext = p; 3450a78c22c4Sdrh p->pPrior = pNew; 3451eb9b884cSdrh SELECTTRACE(2,pParse,p, 3452eb9b884cSdrh ("compound-subquery flattener creates %s.%p as peer\n", 3453eb9b884cSdrh pNew->zSelName, pNew)); 3454d227a291Sdrh } 3455a78c22c4Sdrh if( db->mallocFailed ) return 1; 3456a78c22c4Sdrh } 3457f23329a2Sdanielk1977 34587d10d5a6Sdrh /* Begin flattening the iFrom-th entry of the FROM clause 34597d10d5a6Sdrh ** in the outer query. 3460832508b7Sdrh */ 3461f23329a2Sdanielk1977 pSub = pSub1 = pSubitem->pSelect; 3462c31c2eb8Sdrh 3463a78c22c4Sdrh /* Delete the transient table structure associated with the 3464a78c22c4Sdrh ** subquery 3465a78c22c4Sdrh */ 3466a78c22c4Sdrh sqlite3DbFree(db, pSubitem->zDatabase); 3467a78c22c4Sdrh sqlite3DbFree(db, pSubitem->zName); 3468a78c22c4Sdrh sqlite3DbFree(db, pSubitem->zAlias); 3469a78c22c4Sdrh pSubitem->zDatabase = 0; 3470a78c22c4Sdrh pSubitem->zName = 0; 3471a78c22c4Sdrh pSubitem->zAlias = 0; 3472a78c22c4Sdrh pSubitem->pSelect = 0; 3473a78c22c4Sdrh 3474a78c22c4Sdrh /* Defer deleting the Table object associated with the 3475a78c22c4Sdrh ** subquery until code generation is 3476a78c22c4Sdrh ** complete, since there may still exist Expr.pTab entries that 3477a78c22c4Sdrh ** refer to the subquery even after flattening. Ticket #3346. 3478ccfcbceaSdrh ** 3479ccfcbceaSdrh ** pSubitem->pTab is always non-NULL by test restrictions and tests above. 3480a78c22c4Sdrh */ 3481ccfcbceaSdrh if( ALWAYS(pSubitem->pTab!=0) ){ 3482a78c22c4Sdrh Table *pTabToDel = pSubitem->pTab; 3483a78c22c4Sdrh if( pTabToDel->nRef==1 ){ 348465a7cd16Sdan Parse *pToplevel = sqlite3ParseToplevel(pParse); 348565a7cd16Sdan pTabToDel->pNextZombie = pToplevel->pZombieTab; 348665a7cd16Sdan pToplevel->pZombieTab = pTabToDel; 3487a78c22c4Sdrh }else{ 3488a78c22c4Sdrh pTabToDel->nRef--; 3489a78c22c4Sdrh } 3490a78c22c4Sdrh pSubitem->pTab = 0; 3491a78c22c4Sdrh } 3492a78c22c4Sdrh 3493a78c22c4Sdrh /* The following loop runs once for each term in a compound-subquery 3494a78c22c4Sdrh ** flattening (as described above). If we are doing a different kind 3495a78c22c4Sdrh ** of flattening - a flattening other than a compound-subquery flattening - 3496a78c22c4Sdrh ** then this loop only runs once. 3497a78c22c4Sdrh ** 3498a78c22c4Sdrh ** This loop moves all of the FROM elements of the subquery into the 3499c31c2eb8Sdrh ** the FROM clause of the outer query. Before doing this, remember 3500c31c2eb8Sdrh ** the cursor number for the original outer query FROM element in 3501c31c2eb8Sdrh ** iParent. The iParent cursor will never be used. Subsequent code 3502c31c2eb8Sdrh ** will scan expressions looking for iParent references and replace 3503c31c2eb8Sdrh ** those references with expressions that resolve to the subquery FROM 3504c31c2eb8Sdrh ** elements we are now copying in. 3505c31c2eb8Sdrh */ 3506a78c22c4Sdrh for(pParent=p; pParent; pParent=pParent->pPrior, pSub=pSub->pPrior){ 3507a78c22c4Sdrh int nSubSrc; 3508ea678832Sdrh u8 jointype = 0; 3509a78c22c4Sdrh pSubSrc = pSub->pSrc; /* FROM clause of subquery */ 3510a78c22c4Sdrh nSubSrc = pSubSrc->nSrc; /* Number of terms in subquery FROM clause */ 3511a78c22c4Sdrh pSrc = pParent->pSrc; /* FROM clause of the outer query */ 3512588a9a1aSdrh 3513a78c22c4Sdrh if( pSrc ){ 3514a78c22c4Sdrh assert( pParent==p ); /* First time through the loop */ 3515a78c22c4Sdrh jointype = pSubitem->jointype; 3516588a9a1aSdrh }else{ 3517a78c22c4Sdrh assert( pParent!=p ); /* 2nd and subsequent times through the loop */ 3518a78c22c4Sdrh pSrc = pParent->pSrc = sqlite3SrcListAppend(db, 0, 0, 0); 3519cfa063b3Sdrh if( pSrc==0 ){ 3520a78c22c4Sdrh assert( db->mallocFailed ); 3521a78c22c4Sdrh break; 3522cfa063b3Sdrh } 3523c31c2eb8Sdrh } 3524a78c22c4Sdrh 3525a78c22c4Sdrh /* The subquery uses a single slot of the FROM clause of the outer 3526a78c22c4Sdrh ** query. If the subquery has more than one element in its FROM clause, 3527a78c22c4Sdrh ** then expand the outer query to make space for it to hold all elements 3528a78c22c4Sdrh ** of the subquery. 3529a78c22c4Sdrh ** 3530a78c22c4Sdrh ** Example: 3531a78c22c4Sdrh ** 3532a78c22c4Sdrh ** SELECT * FROM tabA, (SELECT * FROM sub1, sub2), tabB; 3533a78c22c4Sdrh ** 3534a78c22c4Sdrh ** The outer query has 3 slots in its FROM clause. One slot of the 3535a78c22c4Sdrh ** outer query (the middle slot) is used by the subquery. The next 3536a78c22c4Sdrh ** block of code will expand the out query to 4 slots. The middle 3537a78c22c4Sdrh ** slot is expanded to two slots in order to make space for the 3538a78c22c4Sdrh ** two elements in the FROM clause of the subquery. 3539a78c22c4Sdrh */ 3540a78c22c4Sdrh if( nSubSrc>1 ){ 3541a78c22c4Sdrh pParent->pSrc = pSrc = sqlite3SrcListEnlarge(db, pSrc, nSubSrc-1,iFrom+1); 3542a78c22c4Sdrh if( db->mallocFailed ){ 3543a78c22c4Sdrh break; 3544c31c2eb8Sdrh } 3545c31c2eb8Sdrh } 3546a78c22c4Sdrh 3547a78c22c4Sdrh /* Transfer the FROM clause terms from the subquery into the 3548a78c22c4Sdrh ** outer query. 3549a78c22c4Sdrh */ 3550c31c2eb8Sdrh for(i=0; i<nSubSrc; i++){ 3551c3a8402aSdrh sqlite3IdListDelete(db, pSrc->a[i+iFrom].pUsing); 3552c31c2eb8Sdrh pSrc->a[i+iFrom] = pSubSrc->a[i]; 3553c31c2eb8Sdrh memset(&pSubSrc->a[i], 0, sizeof(pSubSrc->a[i])); 3554c31c2eb8Sdrh } 355561dfc31dSdrh pSrc->a[iFrom].jointype = jointype; 3556c31c2eb8Sdrh 3557c31c2eb8Sdrh /* Now begin substituting subquery result set expressions for 3558c31c2eb8Sdrh ** references to the iParent in the outer query. 3559c31c2eb8Sdrh ** 3560c31c2eb8Sdrh ** Example: 3561c31c2eb8Sdrh ** 3562c31c2eb8Sdrh ** SELECT a+5, b*10 FROM (SELECT x*3 AS a, y+10 AS b FROM t1) WHERE a>b; 3563c31c2eb8Sdrh ** \ \_____________ subquery __________/ / 3564c31c2eb8Sdrh ** \_____________________ outer query ______________________________/ 3565c31c2eb8Sdrh ** 3566c31c2eb8Sdrh ** We look at every expression in the outer query and every place we see 3567c31c2eb8Sdrh ** "a" we substitute "x*3" and every place we see "b" we substitute "y+10". 3568c31c2eb8Sdrh */ 3569f23329a2Sdanielk1977 pList = pParent->pEList; 3570832508b7Sdrh for(i=0; i<pList->nExpr; i++){ 3571ccfcbceaSdrh if( pList->a[i].zName==0 ){ 357242fbf321Sdrh char *zName = sqlite3DbStrDup(db, pList->a[i].zSpan); 357342fbf321Sdrh sqlite3Dequote(zName); 357442fbf321Sdrh pList->a[i].zName = zName; 3575832508b7Sdrh } 3576ccfcbceaSdrh } 3577f23329a2Sdanielk1977 substExprList(db, pParent->pEList, iParent, pSub->pEList); 35781b2e0329Sdrh if( isAgg ){ 3579f23329a2Sdanielk1977 substExprList(db, pParent->pGroupBy, iParent, pSub->pEList); 3580b7916a78Sdrh pParent->pHaving = substExpr(db, pParent->pHaving, iParent, pSub->pEList); 35811b2e0329Sdrh } 3582174b6195Sdrh if( pSub->pOrderBy ){ 35837c0a4720Sdan /* At this point, any non-zero iOrderByCol values indicate that the 35847c0a4720Sdan ** ORDER BY column expression is identical to the iOrderByCol'th 35857c0a4720Sdan ** expression returned by SELECT statement pSub. Since these values 35867c0a4720Sdan ** do not necessarily correspond to columns in SELECT statement pParent, 35877c0a4720Sdan ** zero them before transfering the ORDER BY clause. 35887c0a4720Sdan ** 35897c0a4720Sdan ** Not doing this may cause an error if a subsequent call to this 35907c0a4720Sdan ** function attempts to flatten a compound sub-query into pParent 35917c0a4720Sdan ** (the only way this can happen is if the compound sub-query is 35927c0a4720Sdan ** currently part of pSub->pSrc). See ticket [d11a6e908f]. */ 35937c0a4720Sdan ExprList *pOrderBy = pSub->pOrderBy; 35947c0a4720Sdan for(i=0; i<pOrderBy->nExpr; i++){ 35957c0a4720Sdan pOrderBy->a[i].u.x.iOrderByCol = 0; 35967c0a4720Sdan } 3597f23329a2Sdanielk1977 assert( pParent->pOrderBy==0 ); 35987c0a4720Sdan assert( pSub->pPrior==0 ); 35997c0a4720Sdan pParent->pOrderBy = pOrderBy; 3600174b6195Sdrh pSub->pOrderBy = 0; 3601f23329a2Sdanielk1977 }else if( pParent->pOrderBy ){ 3602f23329a2Sdanielk1977 substExprList(db, pParent->pOrderBy, iParent, pSub->pEList); 3603174b6195Sdrh } 3604832508b7Sdrh if( pSub->pWhere ){ 36056ab3a2ecSdanielk1977 pWhere = sqlite3ExprDup(db, pSub->pWhere, 0); 3606832508b7Sdrh }else{ 3607832508b7Sdrh pWhere = 0; 3608832508b7Sdrh } 3609832508b7Sdrh if( subqueryIsAgg ){ 3610f23329a2Sdanielk1977 assert( pParent->pHaving==0 ); 3611f23329a2Sdanielk1977 pParent->pHaving = pParent->pWhere; 3612f23329a2Sdanielk1977 pParent->pWhere = pWhere; 3613b7916a78Sdrh pParent->pHaving = substExpr(db, pParent->pHaving, iParent, pSub->pEList); 3614f23329a2Sdanielk1977 pParent->pHaving = sqlite3ExprAnd(db, pParent->pHaving, 36156ab3a2ecSdanielk1977 sqlite3ExprDup(db, pSub->pHaving, 0)); 3616f23329a2Sdanielk1977 assert( pParent->pGroupBy==0 ); 36176ab3a2ecSdanielk1977 pParent->pGroupBy = sqlite3ExprListDup(db, pSub->pGroupBy, 0); 3618832508b7Sdrh }else{ 3619b7916a78Sdrh pParent->pWhere = substExpr(db, pParent->pWhere, iParent, pSub->pEList); 3620f23329a2Sdanielk1977 pParent->pWhere = sqlite3ExprAnd(db, pParent->pWhere, pWhere); 3621832508b7Sdrh } 3622c31c2eb8Sdrh 3623c31c2eb8Sdrh /* The flattened query is distinct if either the inner or the 3624c31c2eb8Sdrh ** outer query is distinct. 3625c31c2eb8Sdrh */ 36267d10d5a6Sdrh pParent->selFlags |= pSub->selFlags & SF_Distinct; 36278c74a8caSdrh 3628a58fdfb1Sdanielk1977 /* 3629a58fdfb1Sdanielk1977 ** SELECT ... FROM (SELECT ... LIMIT a OFFSET b) LIMIT x OFFSET y; 3630ac83963aSdrh ** 3631ac83963aSdrh ** One is tempted to try to add a and b to combine the limits. But this 3632ac83963aSdrh ** does not work if either limit is negative. 3633a58fdfb1Sdanielk1977 */ 3634a2dc3b1aSdanielk1977 if( pSub->pLimit ){ 3635f23329a2Sdanielk1977 pParent->pLimit = pSub->pLimit; 3636a2dc3b1aSdanielk1977 pSub->pLimit = 0; 3637df199a25Sdrh } 3638f23329a2Sdanielk1977 } 36398c74a8caSdrh 3640c31c2eb8Sdrh /* Finially, delete what is left of the subquery and return 3641c31c2eb8Sdrh ** success. 3642c31c2eb8Sdrh */ 3643633e6d57Sdrh sqlite3SelectDelete(db, pSub1); 3644f23329a2Sdanielk1977 3645c90713d3Sdrh #if SELECTTRACE_ENABLED 3646c90713d3Sdrh if( sqlite3SelectTrace & 0x100 ){ 3647c90713d3Sdrh sqlite3DebugPrintf("After flattening:\n"); 3648c90713d3Sdrh sqlite3TreeViewSelect(0, p, 0); 3649c90713d3Sdrh } 3650c90713d3Sdrh #endif 3651c90713d3Sdrh 3652832508b7Sdrh return 1; 36531350b030Sdrh } 36543514b6f7Sshane #endif /* !defined(SQLITE_OMIT_SUBQUERY) || !defined(SQLITE_OMIT_VIEW) */ 36551350b030Sdrh 36561350b030Sdrh /* 36574ac391fcSdan ** Based on the contents of the AggInfo structure indicated by the first 36584ac391fcSdan ** argument, this function checks if the following are true: 3659a9d1ccb9Sdanielk1977 ** 36604ac391fcSdan ** * the query contains just a single aggregate function, 36614ac391fcSdan ** * the aggregate function is either min() or max(), and 36624ac391fcSdan ** * the argument to the aggregate function is a column value. 3663738bdcfbSdanielk1977 ** 36644ac391fcSdan ** If all of the above are true, then WHERE_ORDERBY_MIN or WHERE_ORDERBY_MAX 36654ac391fcSdan ** is returned as appropriate. Also, *ppMinMax is set to point to the 36664ac391fcSdan ** list of arguments passed to the aggregate before returning. 36674ac391fcSdan ** 36684ac391fcSdan ** Or, if the conditions above are not met, *ppMinMax is set to 0 and 36694ac391fcSdan ** WHERE_ORDERBY_NORMAL is returned. 3670a9d1ccb9Sdanielk1977 */ 36714ac391fcSdan static u8 minMaxQuery(AggInfo *pAggInfo, ExprList **ppMinMax){ 36724ac391fcSdan int eRet = WHERE_ORDERBY_NORMAL; /* Return value */ 3673a9d1ccb9Sdanielk1977 36744ac391fcSdan *ppMinMax = 0; 36754ac391fcSdan if( pAggInfo->nFunc==1 ){ 36764ac391fcSdan Expr *pExpr = pAggInfo->aFunc[0].pExpr; /* Aggregate function */ 36774ac391fcSdan ExprList *pEList = pExpr->x.pList; /* Arguments to agg function */ 36784ac391fcSdan 36794ac391fcSdan assert( pExpr->op==TK_AGG_FUNCTION ); 36804ac391fcSdan if( pEList && pEList->nExpr==1 && pEList->a[0].pExpr->op==TK_AGG_COLUMN ){ 36814ac391fcSdan const char *zFunc = pExpr->u.zToken; 36824ac391fcSdan if( sqlite3StrICmp(zFunc, "min")==0 ){ 36834ac391fcSdan eRet = WHERE_ORDERBY_MIN; 36844ac391fcSdan *ppMinMax = pEList; 36854ac391fcSdan }else if( sqlite3StrICmp(zFunc, "max")==0 ){ 36864ac391fcSdan eRet = WHERE_ORDERBY_MAX; 36874ac391fcSdan *ppMinMax = pEList; 3688a9d1ccb9Sdanielk1977 } 36894ac391fcSdan } 36904ac391fcSdan } 36914ac391fcSdan 36924ac391fcSdan assert( *ppMinMax==0 || (*ppMinMax)->nExpr==1 ); 36934ac391fcSdan return eRet; 3694a9d1ccb9Sdanielk1977 } 3695a9d1ccb9Sdanielk1977 3696a9d1ccb9Sdanielk1977 /* 3697a5533162Sdanielk1977 ** The select statement passed as the first argument is an aggregate query. 369860ec914cSpeter.d.reid ** The second argument is the associated aggregate-info object. This 3699a5533162Sdanielk1977 ** function tests if the SELECT is of the form: 3700a5533162Sdanielk1977 ** 3701a5533162Sdanielk1977 ** SELECT count(*) FROM <tbl> 3702a5533162Sdanielk1977 ** 3703a5533162Sdanielk1977 ** where table is a database table, not a sub-select or view. If the query 3704a5533162Sdanielk1977 ** does match this pattern, then a pointer to the Table object representing 3705a5533162Sdanielk1977 ** <tbl> is returned. Otherwise, 0 is returned. 3706a5533162Sdanielk1977 */ 3707a5533162Sdanielk1977 static Table *isSimpleCount(Select *p, AggInfo *pAggInfo){ 3708a5533162Sdanielk1977 Table *pTab; 3709a5533162Sdanielk1977 Expr *pExpr; 3710a5533162Sdanielk1977 3711a5533162Sdanielk1977 assert( !p->pGroupBy ); 3712a5533162Sdanielk1977 37137a895a80Sdanielk1977 if( p->pWhere || p->pEList->nExpr!=1 3714a5533162Sdanielk1977 || p->pSrc->nSrc!=1 || p->pSrc->a[0].pSelect 3715a5533162Sdanielk1977 ){ 3716a5533162Sdanielk1977 return 0; 3717a5533162Sdanielk1977 } 3718a5533162Sdanielk1977 pTab = p->pSrc->a[0].pTab; 3719a5533162Sdanielk1977 pExpr = p->pEList->a[0].pExpr; 372002f33725Sdanielk1977 assert( pTab && !pTab->pSelect && pExpr ); 372102f33725Sdanielk1977 372202f33725Sdanielk1977 if( IsVirtual(pTab) ) return 0; 3723a5533162Sdanielk1977 if( pExpr->op!=TK_AGG_FUNCTION ) return 0; 3724fb0a6081Sdrh if( NEVER(pAggInfo->nFunc==0) ) return 0; 3725d36e1041Sdrh if( (pAggInfo->aFunc[0].pFunc->funcFlags&SQLITE_FUNC_COUNT)==0 ) return 0; 3726a5533162Sdanielk1977 if( pExpr->flags&EP_Distinct ) return 0; 3727a5533162Sdanielk1977 3728a5533162Sdanielk1977 return pTab; 3729a5533162Sdanielk1977 } 3730a5533162Sdanielk1977 3731a5533162Sdanielk1977 /* 3732b1c685b0Sdanielk1977 ** If the source-list item passed as an argument was augmented with an 3733b1c685b0Sdanielk1977 ** INDEXED BY clause, then try to locate the specified index. If there 3734b1c685b0Sdanielk1977 ** was such a clause and the named index cannot be found, return 3735b1c685b0Sdanielk1977 ** SQLITE_ERROR and leave an error in pParse. Otherwise, populate 3736b1c685b0Sdanielk1977 ** pFrom->pIndex and return SQLITE_OK. 3737b1c685b0Sdanielk1977 */ 3738b1c685b0Sdanielk1977 int sqlite3IndexedByLookup(Parse *pParse, struct SrcList_item *pFrom){ 3739b1c685b0Sdanielk1977 if( pFrom->pTab && pFrom->zIndex ){ 3740b1c685b0Sdanielk1977 Table *pTab = pFrom->pTab; 3741b1c685b0Sdanielk1977 char *zIndex = pFrom->zIndex; 3742b1c685b0Sdanielk1977 Index *pIdx; 3743b1c685b0Sdanielk1977 for(pIdx=pTab->pIndex; 3744b1c685b0Sdanielk1977 pIdx && sqlite3StrICmp(pIdx->zName, zIndex); 3745b1c685b0Sdanielk1977 pIdx=pIdx->pNext 3746b1c685b0Sdanielk1977 ); 3747b1c685b0Sdanielk1977 if( !pIdx ){ 3748b1c685b0Sdanielk1977 sqlite3ErrorMsg(pParse, "no such index: %s", zIndex, 0); 37491db95106Sdan pParse->checkSchema = 1; 3750b1c685b0Sdanielk1977 return SQLITE_ERROR; 3751b1c685b0Sdanielk1977 } 3752b1c685b0Sdanielk1977 pFrom->pIndex = pIdx; 3753b1c685b0Sdanielk1977 } 3754b1c685b0Sdanielk1977 return SQLITE_OK; 3755b1c685b0Sdanielk1977 } 3756c01b7306Sdrh /* 3757c01b7306Sdrh ** Detect compound SELECT statements that use an ORDER BY clause with 3758c01b7306Sdrh ** an alternative collating sequence. 3759c01b7306Sdrh ** 3760c01b7306Sdrh ** SELECT ... FROM t1 EXCEPT SELECT ... FROM t2 ORDER BY .. COLLATE ... 3761c01b7306Sdrh ** 3762c01b7306Sdrh ** These are rewritten as a subquery: 3763c01b7306Sdrh ** 3764c01b7306Sdrh ** SELECT * FROM (SELECT ... FROM t1 EXCEPT SELECT ... FROM t2) 3765c01b7306Sdrh ** ORDER BY ... COLLATE ... 3766c01b7306Sdrh ** 3767c01b7306Sdrh ** This transformation is necessary because the multiSelectOrderBy() routine 3768c01b7306Sdrh ** above that generates the code for a compound SELECT with an ORDER BY clause 3769c01b7306Sdrh ** uses a merge algorithm that requires the same collating sequence on the 3770c01b7306Sdrh ** result columns as on the ORDER BY clause. See ticket 3771c01b7306Sdrh ** http://www.sqlite.org/src/info/6709574d2a 3772c01b7306Sdrh ** 3773c01b7306Sdrh ** This transformation is only needed for EXCEPT, INTERSECT, and UNION. 3774c01b7306Sdrh ** The UNION ALL operator works fine with multiSelectOrderBy() even when 3775c01b7306Sdrh ** there are COLLATE terms in the ORDER BY. 3776c01b7306Sdrh */ 3777c01b7306Sdrh static int convertCompoundSelectToSubquery(Walker *pWalker, Select *p){ 3778c01b7306Sdrh int i; 3779c01b7306Sdrh Select *pNew; 3780c01b7306Sdrh Select *pX; 3781c01b7306Sdrh sqlite3 *db; 3782c01b7306Sdrh struct ExprList_item *a; 3783c01b7306Sdrh SrcList *pNewSrc; 3784c01b7306Sdrh Parse *pParse; 3785c01b7306Sdrh Token dummy; 3786c01b7306Sdrh 3787c01b7306Sdrh if( p->pPrior==0 ) return WRC_Continue; 3788c01b7306Sdrh if( p->pOrderBy==0 ) return WRC_Continue; 3789c01b7306Sdrh for(pX=p; pX && (pX->op==TK_ALL || pX->op==TK_SELECT); pX=pX->pPrior){} 3790c01b7306Sdrh if( pX==0 ) return WRC_Continue; 3791c01b7306Sdrh a = p->pOrderBy->a; 3792c01b7306Sdrh for(i=p->pOrderBy->nExpr-1; i>=0; i--){ 3793c01b7306Sdrh if( a[i].pExpr->flags & EP_Collate ) break; 3794c01b7306Sdrh } 3795c01b7306Sdrh if( i<0 ) return WRC_Continue; 3796c01b7306Sdrh 3797c01b7306Sdrh /* If we reach this point, that means the transformation is required. */ 3798c01b7306Sdrh 3799c01b7306Sdrh pParse = pWalker->pParse; 3800c01b7306Sdrh db = pParse->db; 3801c01b7306Sdrh pNew = sqlite3DbMallocZero(db, sizeof(*pNew) ); 3802c01b7306Sdrh if( pNew==0 ) return WRC_Abort; 3803c01b7306Sdrh memset(&dummy, 0, sizeof(dummy)); 3804c01b7306Sdrh pNewSrc = sqlite3SrcListAppendFromTerm(pParse,0,0,0,&dummy,pNew,0,0); 3805c01b7306Sdrh if( pNewSrc==0 ) return WRC_Abort; 3806c01b7306Sdrh *pNew = *p; 3807c01b7306Sdrh p->pSrc = pNewSrc; 3808c01b7306Sdrh p->pEList = sqlite3ExprListAppend(pParse, 0, sqlite3Expr(db, TK_ALL, 0)); 3809c01b7306Sdrh p->op = TK_SELECT; 3810c01b7306Sdrh p->pWhere = 0; 3811c01b7306Sdrh pNew->pGroupBy = 0; 3812c01b7306Sdrh pNew->pHaving = 0; 3813c01b7306Sdrh pNew->pOrderBy = 0; 3814c01b7306Sdrh p->pPrior = 0; 38158af9ad95Sdrh p->pNext = 0; 38168af9ad95Sdrh p->selFlags &= ~SF_Compound; 3817a6e3a8c9Sdrh assert( pNew->pPrior!=0 ); 3818a6e3a8c9Sdrh pNew->pPrior->pNext = pNew; 3819c01b7306Sdrh pNew->pLimit = 0; 3820c01b7306Sdrh pNew->pOffset = 0; 3821c01b7306Sdrh return WRC_Continue; 3822c01b7306Sdrh } 3823b1c685b0Sdanielk1977 3824eede6a53Sdan #ifndef SQLITE_OMIT_CTE 3825eede6a53Sdan /* 3826eede6a53Sdan ** Argument pWith (which may be NULL) points to a linked list of nested 3827eede6a53Sdan ** WITH contexts, from inner to outermost. If the table identified by 3828eede6a53Sdan ** FROM clause element pItem is really a common-table-expression (CTE) 3829eede6a53Sdan ** then return a pointer to the CTE definition for that table. Otherwise 3830eede6a53Sdan ** return NULL. 383198f45e53Sdan ** 383298f45e53Sdan ** If a non-NULL value is returned, set *ppContext to point to the With 383398f45e53Sdan ** object that the returned CTE belongs to. 383460c1a2f0Sdrh */ 383598f45e53Sdan static struct Cte *searchWith( 383698f45e53Sdan With *pWith, /* Current outermost WITH clause */ 383798f45e53Sdan struct SrcList_item *pItem, /* FROM clause element to resolve */ 383898f45e53Sdan With **ppContext /* OUT: WITH clause return value belongs to */ 383998f45e53Sdan ){ 38407b19f252Sdrh const char *zName; 38417b19f252Sdrh if( pItem->zDatabase==0 && (zName = pItem->zName)!=0 ){ 3842eede6a53Sdan With *p; 3843eede6a53Sdan for(p=pWith; p; p=p->pOuter){ 38444e9119d9Sdan int i; 3845eede6a53Sdan for(i=0; i<p->nCte; i++){ 3846eede6a53Sdan if( sqlite3StrICmp(zName, p->a[i].zName)==0 ){ 384798f45e53Sdan *ppContext = p; 3848eede6a53Sdan return &p->a[i]; 38494e9119d9Sdan } 38504e9119d9Sdan } 38514e9119d9Sdan } 38524e9119d9Sdan } 38534e9119d9Sdan return 0; 38544e9119d9Sdan } 38554e9119d9Sdan 3856c49832c2Sdrh /* The code generator maintains a stack of active WITH clauses 3857c49832c2Sdrh ** with the inner-most WITH clause being at the top of the stack. 3858c49832c2Sdrh ** 3859b290f117Sdan ** This routine pushes the WITH clause passed as the second argument 3860b290f117Sdan ** onto the top of the stack. If argument bFree is true, then this 3861b290f117Sdan ** WITH clause will never be popped from the stack. In this case it 3862b290f117Sdan ** should be freed along with the Parse object. In other cases, when 3863b290f117Sdan ** bFree==0, the With object will be freed along with the SELECT 3864b290f117Sdan ** statement with which it is associated. 3865c49832c2Sdrh */ 3866b290f117Sdan void sqlite3WithPush(Parse *pParse, With *pWith, u8 bFree){ 3867b290f117Sdan assert( bFree==0 || pParse->pWith==0 ); 38684e9119d9Sdan if( pWith ){ 38694e9119d9Sdan pWith->pOuter = pParse->pWith; 38704e9119d9Sdan pParse->pWith = pWith; 3871b290f117Sdan pParse->bFreeWith = bFree; 38724e9119d9Sdan } 38734e9119d9Sdan } 38744e9119d9Sdan 3875eede6a53Sdan /* 3876eede6a53Sdan ** This function checks if argument pFrom refers to a CTE declared by 3877eede6a53Sdan ** a WITH clause on the stack currently maintained by the parser. And, 3878eede6a53Sdan ** if currently processing a CTE expression, if it is a recursive 3879eede6a53Sdan ** reference to the current CTE. 3880eede6a53Sdan ** 3881eede6a53Sdan ** If pFrom falls into either of the two categories above, pFrom->pTab 3882eede6a53Sdan ** and other fields are populated accordingly. The caller should check 3883eede6a53Sdan ** (pFrom->pTab!=0) to determine whether or not a successful match 3884eede6a53Sdan ** was found. 3885eede6a53Sdan ** 3886eede6a53Sdan ** Whether or not a match is found, SQLITE_OK is returned if no error 3887eede6a53Sdan ** occurs. If an error does occur, an error message is stored in the 3888eede6a53Sdan ** parser and some error code other than SQLITE_OK returned. 3889eede6a53Sdan */ 38908ce7184bSdan static int withExpand( 38918ce7184bSdan Walker *pWalker, 3892eede6a53Sdan struct SrcList_item *pFrom 38938ce7184bSdan ){ 38948ce7184bSdan Parse *pParse = pWalker->pParse; 38958ce7184bSdan sqlite3 *db = pParse->db; 389698f45e53Sdan struct Cte *pCte; /* Matched CTE (or NULL if no match) */ 389798f45e53Sdan With *pWith; /* WITH clause that pCte belongs to */ 38988ce7184bSdan 38998ce7184bSdan assert( pFrom->pTab==0 ); 39008ce7184bSdan 390198f45e53Sdan pCte = searchWith(pParse->pWith, pFrom, &pWith); 3902eae73fbfSdan if( pCte ){ 390398f45e53Sdan Table *pTab; 39048ce7184bSdan ExprList *pEList; 39058ce7184bSdan Select *pSel; 390660e7068dSdan Select *pLeft; /* Left-most SELECT statement */ 3907f2655fe8Sdan int bMayRecursive; /* True if compound joined by UNION [ALL] */ 390898f45e53Sdan With *pSavedWith; /* Initial value of pParse->pWith */ 3909f2655fe8Sdan 3910f2655fe8Sdan /* If pCte->zErr is non-NULL at this point, then this is an illegal 3911f2655fe8Sdan ** recursive reference to CTE pCte. Leave an error in pParse and return 3912f2655fe8Sdan ** early. If pCte->zErr is NULL, then this is not a recursive reference. 3913f2655fe8Sdan ** In this case, proceed. */ 3914f2655fe8Sdan if( pCte->zErr ){ 3915f2655fe8Sdan sqlite3ErrorMsg(pParse, pCte->zErr, pCte->zName); 391698f45e53Sdan return SQLITE_ERROR; 3917f2655fe8Sdan } 39188ce7184bSdan 3919c25e2ebcSdrh assert( pFrom->pTab==0 ); 39208ce7184bSdan pFrom->pTab = pTab = sqlite3DbMallocZero(db, sizeof(Table)); 39218ce7184bSdan if( pTab==0 ) return WRC_Abort; 39228ce7184bSdan pTab->nRef = 1; 39232d4dc5fcSdan pTab->zName = sqlite3DbStrDup(db, pCte->zName); 39248ce7184bSdan pTab->iPKey = -1; 3925cfc9df76Sdan pTab->nRowLogEst = 200; assert( 200==sqlite3LogEst(1048576) ); 39268ce7184bSdan pTab->tabFlags |= TF_Ephemeral; 39278ce7184bSdan pFrom->pSelect = sqlite3SelectDup(db, pCte->pSelect, 0); 39288ce7184bSdan if( db->mallocFailed ) return SQLITE_NOMEM; 39298ce7184bSdan assert( pFrom->pSelect ); 39308ce7184bSdan 3931eae73fbfSdan /* Check if this is a recursive CTE. */ 39328ce7184bSdan pSel = pFrom->pSelect; 3933f2655fe8Sdan bMayRecursive = ( pSel->op==TK_ALL || pSel->op==TK_UNION ); 3934f2655fe8Sdan if( bMayRecursive ){ 3935eae73fbfSdan int i; 3936eae73fbfSdan SrcList *pSrc = pFrom->pSelect->pSrc; 3937eae73fbfSdan for(i=0; i<pSrc->nSrc; i++){ 3938eae73fbfSdan struct SrcList_item *pItem = &pSrc->a[i]; 3939eae73fbfSdan if( pItem->zDatabase==0 3940eae73fbfSdan && pItem->zName!=0 3941eae73fbfSdan && 0==sqlite3StrICmp(pItem->zName, pCte->zName) 3942eae73fbfSdan ){ 3943eae73fbfSdan pItem->pTab = pTab; 3944eae73fbfSdan pItem->isRecursive = 1; 3945eae73fbfSdan pTab->nRef++; 3946eae73fbfSdan pSel->selFlags |= SF_Recursive; 39478ce7184bSdan } 3948eae73fbfSdan } 3949eae73fbfSdan } 3950eae73fbfSdan 3951eae73fbfSdan /* Only one recursive reference is permitted. */ 3952eae73fbfSdan if( pTab->nRef>2 ){ 3953eae73fbfSdan sqlite3ErrorMsg( 3954727a99f1Sdrh pParse, "multiple references to recursive table: %s", pCte->zName 3955eae73fbfSdan ); 395698f45e53Sdan return SQLITE_ERROR; 3957eae73fbfSdan } 3958eae73fbfSdan assert( pTab->nRef==1 || ((pSel->selFlags&SF_Recursive) && pTab->nRef==2 )); 3959eae73fbfSdan 3960727a99f1Sdrh pCte->zErr = "circular reference: %s"; 396198f45e53Sdan pSavedWith = pParse->pWith; 396298f45e53Sdan pParse->pWith = pWith; 3963f2655fe8Sdan sqlite3WalkSelect(pWalker, bMayRecursive ? pSel->pPrior : pSel); 39648ce7184bSdan 39658ce7184bSdan for(pLeft=pSel; pLeft->pPrior; pLeft=pLeft->pPrior); 39668ce7184bSdan pEList = pLeft->pEList; 396760e7068dSdan if( pCte->pCols ){ 396860e7068dSdan if( pEList->nExpr!=pCte->pCols->nExpr ){ 3969727a99f1Sdrh sqlite3ErrorMsg(pParse, "table %s has %d values for %d columns", 397060e7068dSdan pCte->zName, pEList->nExpr, pCte->pCols->nExpr 397160e7068dSdan ); 397298f45e53Sdan pParse->pWith = pSavedWith; 397398f45e53Sdan return SQLITE_ERROR; 39748ce7184bSdan } 397560e7068dSdan pEList = pCte->pCols; 397660e7068dSdan } 39778ce7184bSdan 397898f45e53Sdan selectColumnsFromExprList(pParse, pEList, &pTab->nCol, &pTab->aCol); 3979f2655fe8Sdan if( bMayRecursive ){ 3980f2655fe8Sdan if( pSel->selFlags & SF_Recursive ){ 3981727a99f1Sdrh pCte->zErr = "multiple recursive references: %s"; 3982f2655fe8Sdan }else{ 3983727a99f1Sdrh pCte->zErr = "recursive reference in a subquery: %s"; 3984f2655fe8Sdan } 3985f2655fe8Sdan sqlite3WalkSelect(pWalker, pSel); 3986f2655fe8Sdan } 3987f2655fe8Sdan pCte->zErr = 0; 398898f45e53Sdan pParse->pWith = pSavedWith; 39898ce7184bSdan } 39908ce7184bSdan 39918ce7184bSdan return SQLITE_OK; 39928ce7184bSdan } 3993eede6a53Sdan #endif 39944e9119d9Sdan 3995b290f117Sdan #ifndef SQLITE_OMIT_CTE 399671856944Sdan /* 399771856944Sdan ** If the SELECT passed as the second argument has an associated WITH 399871856944Sdan ** clause, pop it from the stack stored as part of the Parse object. 399971856944Sdan ** 400071856944Sdan ** This function is used as the xSelectCallback2() callback by 400171856944Sdan ** sqlite3SelectExpand() when walking a SELECT tree to resolve table 400271856944Sdan ** names and other FROM clause elements. 400371856944Sdan */ 4004b290f117Sdan static void selectPopWith(Walker *pWalker, Select *p){ 4005b290f117Sdan Parse *pParse = pWalker->pParse; 4006d227a291Sdrh With *pWith = findRightmost(p)->pWith; 4007d227a291Sdrh if( pWith!=0 ){ 4008d227a291Sdrh assert( pParse->pWith==pWith ); 4009d227a291Sdrh pParse->pWith = pWith->pOuter; 4010b290f117Sdan } 4011b290f117Sdan } 4012b290f117Sdan #else 4013b290f117Sdan #define selectPopWith 0 4014b290f117Sdan #endif 4015b290f117Sdan 4016b1c685b0Sdanielk1977 /* 40177d10d5a6Sdrh ** This routine is a Walker callback for "expanding" a SELECT statement. 40187d10d5a6Sdrh ** "Expanding" means to do the following: 40197d10d5a6Sdrh ** 40207d10d5a6Sdrh ** (1) Make sure VDBE cursor numbers have been assigned to every 40217d10d5a6Sdrh ** element of the FROM clause. 40227d10d5a6Sdrh ** 40237d10d5a6Sdrh ** (2) Fill in the pTabList->a[].pTab fields in the SrcList that 40247d10d5a6Sdrh ** defines FROM clause. When views appear in the FROM clause, 40257d10d5a6Sdrh ** fill pTabList->a[].pSelect with a copy of the SELECT statement 40267d10d5a6Sdrh ** that implements the view. A copy is made of the view's SELECT 40277d10d5a6Sdrh ** statement so that we can freely modify or delete that statement 402860ec914cSpeter.d.reid ** without worrying about messing up the persistent representation 40297d10d5a6Sdrh ** of the view. 40307d10d5a6Sdrh ** 403160ec914cSpeter.d.reid ** (3) Add terms to the WHERE clause to accommodate the NATURAL keyword 40327d10d5a6Sdrh ** on joins and the ON and USING clause of joins. 40337d10d5a6Sdrh ** 40347d10d5a6Sdrh ** (4) Scan the list of columns in the result set (pEList) looking 40357d10d5a6Sdrh ** for instances of the "*" operator or the TABLE.* operator. 40367d10d5a6Sdrh ** If found, expand each "*" to be every column in every table 40377d10d5a6Sdrh ** and TABLE.* to be every column in TABLE. 40387d10d5a6Sdrh ** 4039b3bce662Sdanielk1977 */ 40407d10d5a6Sdrh static int selectExpander(Walker *pWalker, Select *p){ 40417d10d5a6Sdrh Parse *pParse = pWalker->pParse; 40427d10d5a6Sdrh int i, j, k; 40437d10d5a6Sdrh SrcList *pTabList; 40447d10d5a6Sdrh ExprList *pEList; 40457d10d5a6Sdrh struct SrcList_item *pFrom; 40467d10d5a6Sdrh sqlite3 *db = pParse->db; 40473e3f1a5bSdrh Expr *pE, *pRight, *pExpr; 4048785097daSdrh u16 selFlags = p->selFlags; 40497d10d5a6Sdrh 4050785097daSdrh p->selFlags |= SF_Expanded; 40517d10d5a6Sdrh if( db->mallocFailed ){ 40527d10d5a6Sdrh return WRC_Abort; 40537d10d5a6Sdrh } 4054785097daSdrh if( NEVER(p->pSrc==0) || (selFlags & SF_Expanded)!=0 ){ 40557d10d5a6Sdrh return WRC_Prune; 40567d10d5a6Sdrh } 40577d10d5a6Sdrh pTabList = p->pSrc; 40587d10d5a6Sdrh pEList = p->pEList; 4059d227a291Sdrh sqlite3WithPush(pParse, findRightmost(p)->pWith, 0); 40607d10d5a6Sdrh 40617d10d5a6Sdrh /* Make sure cursor numbers have been assigned to all entries in 40627d10d5a6Sdrh ** the FROM clause of the SELECT statement. 40637d10d5a6Sdrh */ 40647d10d5a6Sdrh sqlite3SrcListAssignCursors(pParse, pTabList); 40657d10d5a6Sdrh 40667d10d5a6Sdrh /* Look up every table named in the FROM clause of the select. If 40677d10d5a6Sdrh ** an entry of the FROM clause is a subquery instead of a table or view, 40687d10d5a6Sdrh ** then create a transient table structure to describe the subquery. 40697d10d5a6Sdrh */ 40707d10d5a6Sdrh for(i=0, pFrom=pTabList->a; i<pTabList->nSrc; i++, pFrom++){ 40717d10d5a6Sdrh Table *pTab; 4072eae73fbfSdan assert( pFrom->isRecursive==0 || pFrom->pTab ); 4073eae73fbfSdan if( pFrom->isRecursive ) continue; 40747d10d5a6Sdrh if( pFrom->pTab!=0 ){ 40757d10d5a6Sdrh /* This statement has already been prepared. There is no need 40767d10d5a6Sdrh ** to go further. */ 40777d10d5a6Sdrh assert( i==0 ); 4078b290f117Sdan #ifndef SQLITE_OMIT_CTE 4079b290f117Sdan selectPopWith(pWalker, p); 4080b290f117Sdan #endif 40817d10d5a6Sdrh return WRC_Prune; 40827d10d5a6Sdrh } 40834e9119d9Sdan #ifndef SQLITE_OMIT_CTE 4084eede6a53Sdan if( withExpand(pWalker, pFrom) ) return WRC_Abort; 4085eede6a53Sdan if( pFrom->pTab ) {} else 40864e9119d9Sdan #endif 40877d10d5a6Sdrh if( pFrom->zName==0 ){ 40887d10d5a6Sdrh #ifndef SQLITE_OMIT_SUBQUERY 40897d10d5a6Sdrh Select *pSel = pFrom->pSelect; 40907d10d5a6Sdrh /* A sub-query in the FROM clause of a SELECT */ 40917d10d5a6Sdrh assert( pSel!=0 ); 40927d10d5a6Sdrh assert( pFrom->pTab==0 ); 40937d10d5a6Sdrh sqlite3WalkSelect(pWalker, pSel); 40947d10d5a6Sdrh pFrom->pTab = pTab = sqlite3DbMallocZero(db, sizeof(Table)); 40957d10d5a6Sdrh if( pTab==0 ) return WRC_Abort; 40967d10d5a6Sdrh pTab->nRef = 1; 4097186ad8ccSdrh pTab->zName = sqlite3MPrintf(db, "sqlite_sq_%p", (void*)pTab); 40987d10d5a6Sdrh while( pSel->pPrior ){ pSel = pSel->pPrior; } 40997d10d5a6Sdrh selectColumnsFromExprList(pParse, pSel->pEList, &pTab->nCol, &pTab->aCol); 41007d10d5a6Sdrh pTab->iPKey = -1; 4101cfc9df76Sdan pTab->nRowLogEst = 200; assert( 200==sqlite3LogEst(1048576) ); 41027d10d5a6Sdrh pTab->tabFlags |= TF_Ephemeral; 41037d10d5a6Sdrh #endif 41047d10d5a6Sdrh }else{ 41057d10d5a6Sdrh /* An ordinary table or view name in the FROM clause */ 41067d10d5a6Sdrh assert( pFrom->pTab==0 ); 410741fb5cd1Sdan pFrom->pTab = pTab = sqlite3LocateTableItem(pParse, 0, pFrom); 41087d10d5a6Sdrh if( pTab==0 ) return WRC_Abort; 4109d2a56238Sdrh if( pTab->nRef==0xffff ){ 4110d2a56238Sdrh sqlite3ErrorMsg(pParse, "too many references to \"%s\": max 65535", 4111d2a56238Sdrh pTab->zName); 4112d2a56238Sdrh pFrom->pTab = 0; 4113d2a56238Sdrh return WRC_Abort; 4114d2a56238Sdrh } 41157d10d5a6Sdrh pTab->nRef++; 41167d10d5a6Sdrh #if !defined(SQLITE_OMIT_VIEW) || !defined (SQLITE_OMIT_VIRTUALTABLE) 41177d10d5a6Sdrh if( pTab->pSelect || IsVirtual(pTab) ){ 41187d10d5a6Sdrh /* We reach here if the named table is a really a view */ 41197d10d5a6Sdrh if( sqlite3ViewGetColumnNames(pParse, pTab) ) return WRC_Abort; 412043152cf8Sdrh assert( pFrom->pSelect==0 ); 41216ab3a2ecSdanielk1977 pFrom->pSelect = sqlite3SelectDup(db, pTab->pSelect, 0); 4122eb9b884cSdrh sqlite3SelectSetName(pFrom->pSelect, pTab->zName); 41237d10d5a6Sdrh sqlite3WalkSelect(pWalker, pFrom->pSelect); 41247d10d5a6Sdrh } 41257d10d5a6Sdrh #endif 41267d10d5a6Sdrh } 412785574e31Sdanielk1977 412885574e31Sdanielk1977 /* Locate the index named by the INDEXED BY clause, if any. */ 4129b1c685b0Sdanielk1977 if( sqlite3IndexedByLookup(pParse, pFrom) ){ 413085574e31Sdanielk1977 return WRC_Abort; 413185574e31Sdanielk1977 } 41327d10d5a6Sdrh } 41337d10d5a6Sdrh 41347d10d5a6Sdrh /* Process NATURAL keywords, and ON and USING clauses of joins. 41357d10d5a6Sdrh */ 41367d10d5a6Sdrh if( db->mallocFailed || sqliteProcessJoin(pParse, p) ){ 41377d10d5a6Sdrh return WRC_Abort; 41387d10d5a6Sdrh } 41397d10d5a6Sdrh 41407d10d5a6Sdrh /* For every "*" that occurs in the column list, insert the names of 41417d10d5a6Sdrh ** all columns in all tables. And for every TABLE.* insert the names 41427d10d5a6Sdrh ** of all columns in TABLE. The parser inserted a special expression 41437d10d5a6Sdrh ** with the TK_ALL operator for each "*" that it found in the column list. 41447d10d5a6Sdrh ** The following code just has to locate the TK_ALL expressions and expand 41457d10d5a6Sdrh ** each one to the list of all columns in all tables. 41467d10d5a6Sdrh ** 41477d10d5a6Sdrh ** The first loop just checks to see if there are any "*" operators 41487d10d5a6Sdrh ** that need expanding. 41497d10d5a6Sdrh */ 41507d10d5a6Sdrh for(k=0; k<pEList->nExpr; k++){ 41513e3f1a5bSdrh pE = pEList->a[k].pExpr; 41527d10d5a6Sdrh if( pE->op==TK_ALL ) break; 415343152cf8Sdrh assert( pE->op!=TK_DOT || pE->pRight!=0 ); 415443152cf8Sdrh assert( pE->op!=TK_DOT || (pE->pLeft!=0 && pE->pLeft->op==TK_ID) ); 415543152cf8Sdrh if( pE->op==TK_DOT && pE->pRight->op==TK_ALL ) break; 41567d10d5a6Sdrh } 41577d10d5a6Sdrh if( k<pEList->nExpr ){ 41587d10d5a6Sdrh /* 41597d10d5a6Sdrh ** If we get here it means the result set contains one or more "*" 41607d10d5a6Sdrh ** operators that need to be expanded. Loop through each expression 41617d10d5a6Sdrh ** in the result set and expand them one by one. 41627d10d5a6Sdrh */ 41637d10d5a6Sdrh struct ExprList_item *a = pEList->a; 41647d10d5a6Sdrh ExprList *pNew = 0; 41657d10d5a6Sdrh int flags = pParse->db->flags; 41667d10d5a6Sdrh int longNames = (flags & SQLITE_FullColNames)!=0 416738b384a0Sdrh && (flags & SQLITE_ShortColNames)==0; 416838b384a0Sdrh 416938b384a0Sdrh /* When processing FROM-clause subqueries, it is always the case 417038b384a0Sdrh ** that full_column_names=OFF and short_column_names=ON. The 417138b384a0Sdrh ** sqlite3ResultSetOfSelect() routine makes it so. */ 417238b384a0Sdrh assert( (p->selFlags & SF_NestedFrom)==0 417338b384a0Sdrh || ((flags & SQLITE_FullColNames)==0 && 417438b384a0Sdrh (flags & SQLITE_ShortColNames)!=0) ); 41757d10d5a6Sdrh 41767d10d5a6Sdrh for(k=0; k<pEList->nExpr; k++){ 41773e3f1a5bSdrh pE = a[k].pExpr; 41783e3f1a5bSdrh pRight = pE->pRight; 41793e3f1a5bSdrh assert( pE->op!=TK_DOT || pRight!=0 ); 41803e3f1a5bSdrh if( pE->op!=TK_ALL && (pE->op!=TK_DOT || pRight->op!=TK_ALL) ){ 41817d10d5a6Sdrh /* This particular expression does not need to be expanded. 41827d10d5a6Sdrh */ 4183b7916a78Sdrh pNew = sqlite3ExprListAppend(pParse, pNew, a[k].pExpr); 41847d10d5a6Sdrh if( pNew ){ 41857d10d5a6Sdrh pNew->a[pNew->nExpr-1].zName = a[k].zName; 4186b7916a78Sdrh pNew->a[pNew->nExpr-1].zSpan = a[k].zSpan; 4187b7916a78Sdrh a[k].zName = 0; 4188b7916a78Sdrh a[k].zSpan = 0; 41897d10d5a6Sdrh } 41907d10d5a6Sdrh a[k].pExpr = 0; 41917d10d5a6Sdrh }else{ 41927d10d5a6Sdrh /* This expression is a "*" or a "TABLE.*" and needs to be 41937d10d5a6Sdrh ** expanded. */ 41947d10d5a6Sdrh int tableSeen = 0; /* Set to 1 when TABLE matches */ 41953e3f1a5bSdrh char *zTName = 0; /* text of name of TABLE */ 419643152cf8Sdrh if( pE->op==TK_DOT ){ 419743152cf8Sdrh assert( pE->pLeft!=0 ); 419833e619fcSdrh assert( !ExprHasProperty(pE->pLeft, EP_IntValue) ); 419933e619fcSdrh zTName = pE->pLeft->u.zToken; 42007d10d5a6Sdrh } 42017d10d5a6Sdrh for(i=0, pFrom=pTabList->a; i<pTabList->nSrc; i++, pFrom++){ 42027d10d5a6Sdrh Table *pTab = pFrom->pTab; 42033e3f1a5bSdrh Select *pSub = pFrom->pSelect; 42047d10d5a6Sdrh char *zTabName = pFrom->zAlias; 42053e3f1a5bSdrh const char *zSchemaName = 0; 4206c75e09c7Sdrh int iDb; 420743152cf8Sdrh if( zTabName==0 ){ 42087d10d5a6Sdrh zTabName = pTab->zName; 42097d10d5a6Sdrh } 42107d10d5a6Sdrh if( db->mallocFailed ) break; 42113e3f1a5bSdrh if( pSub==0 || (pSub->selFlags & SF_NestedFrom)==0 ){ 42123e3f1a5bSdrh pSub = 0; 42137d10d5a6Sdrh if( zTName && sqlite3StrICmp(zTName, zTabName)!=0 ){ 42147d10d5a6Sdrh continue; 42157d10d5a6Sdrh } 42163e3f1a5bSdrh iDb = sqlite3SchemaToIndex(db, pTab->pSchema); 4217c75e09c7Sdrh zSchemaName = iDb>=0 ? db->aDb[iDb].zName : "*"; 42183e3f1a5bSdrh } 42197d10d5a6Sdrh for(j=0; j<pTab->nCol; j++){ 42207d10d5a6Sdrh char *zName = pTab->aCol[j].zName; 4221b7916a78Sdrh char *zColname; /* The computed column name */ 4222b7916a78Sdrh char *zToFree; /* Malloced string that needs to be freed */ 4223b7916a78Sdrh Token sColname; /* Computed column name as a token */ 42247d10d5a6Sdrh 4225c75e09c7Sdrh assert( zName ); 42263e3f1a5bSdrh if( zTName && pSub 42273e3f1a5bSdrh && sqlite3MatchSpanName(pSub->pEList->a[j].zSpan, 0, zTName, 0)==0 42283e3f1a5bSdrh ){ 42293e3f1a5bSdrh continue; 42303e3f1a5bSdrh } 42313e3f1a5bSdrh 42327d10d5a6Sdrh /* If a column is marked as 'hidden' (currently only possible 42337d10d5a6Sdrh ** for virtual tables), do not include it in the expanded 42347d10d5a6Sdrh ** result-set list. 42357d10d5a6Sdrh */ 42367d10d5a6Sdrh if( IsHiddenColumn(&pTab->aCol[j]) ){ 42377d10d5a6Sdrh assert(IsVirtual(pTab)); 42387d10d5a6Sdrh continue; 42397d10d5a6Sdrh } 42403e3f1a5bSdrh tableSeen = 1; 42417d10d5a6Sdrh 4242da55c48aSdrh if( i>0 && zTName==0 ){ 42432179b434Sdrh if( (pFrom->jointype & JT_NATURAL)!=0 42442179b434Sdrh && tableAndColumnIndex(pTabList, i, zName, 0, 0) 42452179b434Sdrh ){ 42467d10d5a6Sdrh /* In a NATURAL join, omit the join columns from the 42472179b434Sdrh ** table to the right of the join */ 42487d10d5a6Sdrh continue; 42497d10d5a6Sdrh } 42502179b434Sdrh if( sqlite3IdListIndex(pFrom->pUsing, zName)>=0 ){ 42517d10d5a6Sdrh /* In a join with a USING clause, omit columns in the 42527d10d5a6Sdrh ** using clause from the table on the right. */ 42537d10d5a6Sdrh continue; 42547d10d5a6Sdrh } 42557d10d5a6Sdrh } 4256b7916a78Sdrh pRight = sqlite3Expr(db, TK_ID, zName); 4257b7916a78Sdrh zColname = zName; 4258b7916a78Sdrh zToFree = 0; 42597d10d5a6Sdrh if( longNames || pTabList->nSrc>1 ){ 4260b7916a78Sdrh Expr *pLeft; 4261b7916a78Sdrh pLeft = sqlite3Expr(db, TK_ID, zTabName); 42627d10d5a6Sdrh pExpr = sqlite3PExpr(pParse, TK_DOT, pLeft, pRight, 0); 426338b384a0Sdrh if( zSchemaName ){ 4264c75e09c7Sdrh pLeft = sqlite3Expr(db, TK_ID, zSchemaName); 4265c75e09c7Sdrh pExpr = sqlite3PExpr(pParse, TK_DOT, pLeft, pExpr, 0); 4266c75e09c7Sdrh } 4267b7916a78Sdrh if( longNames ){ 4268b7916a78Sdrh zColname = sqlite3MPrintf(db, "%s.%s", zTabName, zName); 4269b7916a78Sdrh zToFree = zColname; 4270b7916a78Sdrh } 42717d10d5a6Sdrh }else{ 42727d10d5a6Sdrh pExpr = pRight; 42737d10d5a6Sdrh } 4274b7916a78Sdrh pNew = sqlite3ExprListAppend(pParse, pNew, pExpr); 4275b7916a78Sdrh sColname.z = zColname; 4276b7916a78Sdrh sColname.n = sqlite3Strlen30(zColname); 4277b7916a78Sdrh sqlite3ExprListSetName(pParse, pNew, &sColname, 0); 42788f25d18bSdrh if( pNew && (p->selFlags & SF_NestedFrom)!=0 ){ 42793e3f1a5bSdrh struct ExprList_item *pX = &pNew->a[pNew->nExpr-1]; 42803e3f1a5bSdrh if( pSub ){ 42813e3f1a5bSdrh pX->zSpan = sqlite3DbStrDup(db, pSub->pEList->a[j].zSpan); 4282c75e09c7Sdrh testcase( pX->zSpan==0 ); 42833e3f1a5bSdrh }else{ 42843e3f1a5bSdrh pX->zSpan = sqlite3MPrintf(db, "%s.%s.%s", 42853e3f1a5bSdrh zSchemaName, zTabName, zColname); 4286c75e09c7Sdrh testcase( pX->zSpan==0 ); 42873e3f1a5bSdrh } 42883e3f1a5bSdrh pX->bSpanIsTab = 1; 42898f25d18bSdrh } 4290b7916a78Sdrh sqlite3DbFree(db, zToFree); 42917d10d5a6Sdrh } 42927d10d5a6Sdrh } 42937d10d5a6Sdrh if( !tableSeen ){ 42947d10d5a6Sdrh if( zTName ){ 42957d10d5a6Sdrh sqlite3ErrorMsg(pParse, "no such table: %s", zTName); 42967d10d5a6Sdrh }else{ 42977d10d5a6Sdrh sqlite3ErrorMsg(pParse, "no tables specified"); 42987d10d5a6Sdrh } 42997d10d5a6Sdrh } 43007d10d5a6Sdrh } 43017d10d5a6Sdrh } 43027d10d5a6Sdrh sqlite3ExprListDelete(db, pEList); 43037d10d5a6Sdrh p->pEList = pNew; 43047d10d5a6Sdrh } 43057d10d5a6Sdrh #if SQLITE_MAX_COLUMN 43067d10d5a6Sdrh if( p->pEList && p->pEList->nExpr>db->aLimit[SQLITE_LIMIT_COLUMN] ){ 43077d10d5a6Sdrh sqlite3ErrorMsg(pParse, "too many columns in result set"); 43087d10d5a6Sdrh } 43097d10d5a6Sdrh #endif 43107d10d5a6Sdrh return WRC_Continue; 43117d10d5a6Sdrh } 43127d10d5a6Sdrh 43137d10d5a6Sdrh /* 43147d10d5a6Sdrh ** No-op routine for the parse-tree walker. 43157d10d5a6Sdrh ** 43167d10d5a6Sdrh ** When this routine is the Walker.xExprCallback then expression trees 43177d10d5a6Sdrh ** are walked without any actions being taken at each node. Presumably, 43187d10d5a6Sdrh ** when this routine is used for Walker.xExprCallback then 43197d10d5a6Sdrh ** Walker.xSelectCallback is set to do something useful for every 43207d10d5a6Sdrh ** subquery in the parser tree. 43217d10d5a6Sdrh */ 432262c14b34Sdanielk1977 static int exprWalkNoop(Walker *NotUsed, Expr *NotUsed2){ 432362c14b34Sdanielk1977 UNUSED_PARAMETER2(NotUsed, NotUsed2); 43247d10d5a6Sdrh return WRC_Continue; 43257d10d5a6Sdrh } 43267d10d5a6Sdrh 43277d10d5a6Sdrh /* 43287d10d5a6Sdrh ** This routine "expands" a SELECT statement and all of its subqueries. 43297d10d5a6Sdrh ** For additional information on what it means to "expand" a SELECT 43307d10d5a6Sdrh ** statement, see the comment on the selectExpand worker callback above. 43317d10d5a6Sdrh ** 43327d10d5a6Sdrh ** Expanding a SELECT statement is the first step in processing a 43337d10d5a6Sdrh ** SELECT statement. The SELECT statement must be expanded before 43347d10d5a6Sdrh ** name resolution is performed. 43357d10d5a6Sdrh ** 43367d10d5a6Sdrh ** If anything goes wrong, an error message is written into pParse. 43377d10d5a6Sdrh ** The calling function can detect the problem by looking at pParse->nErr 43387d10d5a6Sdrh ** and/or pParse->db->mallocFailed. 43397d10d5a6Sdrh */ 43407d10d5a6Sdrh static void sqlite3SelectExpand(Parse *pParse, Select *pSelect){ 43417d10d5a6Sdrh Walker w; 4342aa87f9a6Sdrh memset(&w, 0, sizeof(w)); 43437d10d5a6Sdrh w.xExprCallback = exprWalkNoop; 43447d10d5a6Sdrh w.pParse = pParse; 4345d58d3278Sdrh if( pParse->hasCompound ){ 4346d58d3278Sdrh w.xSelectCallback = convertCompoundSelectToSubquery; 43477d10d5a6Sdrh sqlite3WalkSelect(&w, pSelect); 4348d58d3278Sdrh } 4349c01b7306Sdrh w.xSelectCallback = selectExpander; 4350b290f117Sdan w.xSelectCallback2 = selectPopWith; 4351c01b7306Sdrh sqlite3WalkSelect(&w, pSelect); 43527d10d5a6Sdrh } 43537d10d5a6Sdrh 43547d10d5a6Sdrh 43557d10d5a6Sdrh #ifndef SQLITE_OMIT_SUBQUERY 43567d10d5a6Sdrh /* 43577d10d5a6Sdrh ** This is a Walker.xSelectCallback callback for the sqlite3SelectTypeInfo() 43587d10d5a6Sdrh ** interface. 43597d10d5a6Sdrh ** 43607d10d5a6Sdrh ** For each FROM-clause subquery, add Column.zType and Column.zColl 43617d10d5a6Sdrh ** information to the Table structure that represents the result set 43627d10d5a6Sdrh ** of that subquery. 43637d10d5a6Sdrh ** 43647d10d5a6Sdrh ** The Table structure that represents the result set was constructed 43657d10d5a6Sdrh ** by selectExpander() but the type and collation information was omitted 43667d10d5a6Sdrh ** at that point because identifiers had not yet been resolved. This 43677d10d5a6Sdrh ** routine is called after identifier resolution. 43687d10d5a6Sdrh */ 4369b290f117Sdan static void selectAddSubqueryTypeInfo(Walker *pWalker, Select *p){ 43707d10d5a6Sdrh Parse *pParse; 43717d10d5a6Sdrh int i; 43727d10d5a6Sdrh SrcList *pTabList; 43737d10d5a6Sdrh struct SrcList_item *pFrom; 43747d10d5a6Sdrh 43759d8b3072Sdrh assert( p->selFlags & SF_Resolved ); 43765a29d9cbSdrh if( (p->selFlags & SF_HasTypeInfo)==0 ){ 43777d10d5a6Sdrh p->selFlags |= SF_HasTypeInfo; 43787d10d5a6Sdrh pParse = pWalker->pParse; 43797d10d5a6Sdrh pTabList = p->pSrc; 43807d10d5a6Sdrh for(i=0, pFrom=pTabList->a; i<pTabList->nSrc; i++, pFrom++){ 43817d10d5a6Sdrh Table *pTab = pFrom->pTab; 438243152cf8Sdrh if( ALWAYS(pTab!=0) && (pTab->tabFlags & TF_Ephemeral)!=0 ){ 43837d10d5a6Sdrh /* A sub-query in the FROM clause of a SELECT */ 43847d10d5a6Sdrh Select *pSel = pFrom->pSelect; 43858ce7184bSdan if( pSel ){ 43867d10d5a6Sdrh while( pSel->pPrior ) pSel = pSel->pPrior; 4387186ad8ccSdrh selectAddColumnTypeAndCollation(pParse, pTab, pSel); 43887d10d5a6Sdrh } 43897d10d5a6Sdrh } 43905a29d9cbSdrh } 43918ce7184bSdan } 43927d10d5a6Sdrh } 43937d10d5a6Sdrh #endif 43947d10d5a6Sdrh 43957d10d5a6Sdrh 43967d10d5a6Sdrh /* 43977d10d5a6Sdrh ** This routine adds datatype and collating sequence information to 43987d10d5a6Sdrh ** the Table structures of all FROM-clause subqueries in a 43997d10d5a6Sdrh ** SELECT statement. 44007d10d5a6Sdrh ** 44017d10d5a6Sdrh ** Use this routine after name resolution. 44027d10d5a6Sdrh */ 44037d10d5a6Sdrh static void sqlite3SelectAddTypeInfo(Parse *pParse, Select *pSelect){ 44047d10d5a6Sdrh #ifndef SQLITE_OMIT_SUBQUERY 44057d10d5a6Sdrh Walker w; 4406aa87f9a6Sdrh memset(&w, 0, sizeof(w)); 4407b290f117Sdan w.xSelectCallback2 = selectAddSubqueryTypeInfo; 44087d10d5a6Sdrh w.xExprCallback = exprWalkNoop; 44097d10d5a6Sdrh w.pParse = pParse; 44107d10d5a6Sdrh sqlite3WalkSelect(&w, pSelect); 44117d10d5a6Sdrh #endif 44127d10d5a6Sdrh } 44137d10d5a6Sdrh 44147d10d5a6Sdrh 44157d10d5a6Sdrh /* 4416030796dfSdrh ** This routine sets up a SELECT statement for processing. The 44177d10d5a6Sdrh ** following is accomplished: 44187d10d5a6Sdrh ** 44197d10d5a6Sdrh ** * VDBE Cursor numbers are assigned to all FROM-clause terms. 44207d10d5a6Sdrh ** * Ephemeral Table objects are created for all FROM-clause subqueries. 44217d10d5a6Sdrh ** * ON and USING clauses are shifted into WHERE statements 44227d10d5a6Sdrh ** * Wildcards "*" and "TABLE.*" in result sets are expanded. 44237d10d5a6Sdrh ** * Identifiers in expression are matched to tables. 44247d10d5a6Sdrh ** 44257d10d5a6Sdrh ** This routine acts recursively on all subqueries within the SELECT. 44267d10d5a6Sdrh */ 44277d10d5a6Sdrh void sqlite3SelectPrep( 4428b3bce662Sdanielk1977 Parse *pParse, /* The parser context */ 4429b3bce662Sdanielk1977 Select *p, /* The SELECT statement being coded. */ 44307d10d5a6Sdrh NameContext *pOuterNC /* Name context for container */ 4431b3bce662Sdanielk1977 ){ 44327d10d5a6Sdrh sqlite3 *db; 443343152cf8Sdrh if( NEVER(p==0) ) return; 44347d10d5a6Sdrh db = pParse->db; 4435785097daSdrh if( db->mallocFailed ) return; 44367d10d5a6Sdrh if( p->selFlags & SF_HasTypeInfo ) return; 44377d10d5a6Sdrh sqlite3SelectExpand(pParse, p); 44387d10d5a6Sdrh if( pParse->nErr || db->mallocFailed ) return; 44397d10d5a6Sdrh sqlite3ResolveSelectNames(pParse, p, pOuterNC); 44407d10d5a6Sdrh if( pParse->nErr || db->mallocFailed ) return; 44417d10d5a6Sdrh sqlite3SelectAddTypeInfo(pParse, p); 4442f6bbe022Sdrh } 4443b3bce662Sdanielk1977 4444b3bce662Sdanielk1977 /* 444513449892Sdrh ** Reset the aggregate accumulator. 444613449892Sdrh ** 444713449892Sdrh ** The aggregate accumulator is a set of memory cells that hold 444813449892Sdrh ** intermediate results while calculating an aggregate. This 4449030796dfSdrh ** routine generates code that stores NULLs in all of those memory 4450030796dfSdrh ** cells. 4451b3bce662Sdanielk1977 */ 445213449892Sdrh static void resetAccumulator(Parse *pParse, AggInfo *pAggInfo){ 445313449892Sdrh Vdbe *v = pParse->pVdbe; 445413449892Sdrh int i; 4455c99130fdSdrh struct AggInfo_func *pFunc; 44567e61d18eSdrh int nReg = pAggInfo->nFunc + pAggInfo->nColumn; 44577e61d18eSdrh if( nReg==0 ) return; 44587e61d18eSdrh #ifdef SQLITE_DEBUG 44597e61d18eSdrh /* Verify that all AggInfo registers are within the range specified by 44607e61d18eSdrh ** AggInfo.mnReg..AggInfo.mxReg */ 44617e61d18eSdrh assert( nReg==pAggInfo->mxReg-pAggInfo->mnReg+1 ); 446213449892Sdrh for(i=0; i<pAggInfo->nColumn; i++){ 44637e61d18eSdrh assert( pAggInfo->aCol[i].iMem>=pAggInfo->mnReg 44647e61d18eSdrh && pAggInfo->aCol[i].iMem<=pAggInfo->mxReg ); 446513449892Sdrh } 44667e61d18eSdrh for(i=0; i<pAggInfo->nFunc; i++){ 44677e61d18eSdrh assert( pAggInfo->aFunc[i].iMem>=pAggInfo->mnReg 44687e61d18eSdrh && pAggInfo->aFunc[i].iMem<=pAggInfo->mxReg ); 44697e61d18eSdrh } 44707e61d18eSdrh #endif 44717e61d18eSdrh sqlite3VdbeAddOp3(v, OP_Null, 0, pAggInfo->mnReg, pAggInfo->mxReg); 4472c99130fdSdrh for(pFunc=pAggInfo->aFunc, i=0; i<pAggInfo->nFunc; i++, pFunc++){ 4473c99130fdSdrh if( pFunc->iDistinct>=0 ){ 4474c99130fdSdrh Expr *pE = pFunc->pExpr; 44756ab3a2ecSdanielk1977 assert( !ExprHasProperty(pE, EP_xIsSelect) ); 44766ab3a2ecSdanielk1977 if( pE->x.pList==0 || pE->x.pList->nExpr!=1 ){ 44770daa002cSdrh sqlite3ErrorMsg(pParse, "DISTINCT aggregates must have exactly one " 44780daa002cSdrh "argument"); 4479c99130fdSdrh pFunc->iDistinct = -1; 4480c99130fdSdrh }else{ 4481079a3072Sdrh KeyInfo *pKeyInfo = keyInfoFromExprList(pParse, pE->x.pList, 0, 0); 448266a5167bSdrh sqlite3VdbeAddOp4(v, OP_OpenEphemeral, pFunc->iDistinct, 0, 0, 44832ec2fb22Sdrh (char*)pKeyInfo, P4_KEYINFO); 4484c99130fdSdrh } 4485c99130fdSdrh } 448613449892Sdrh } 4487b3bce662Sdanielk1977 } 4488b3bce662Sdanielk1977 4489b3bce662Sdanielk1977 /* 449013449892Sdrh ** Invoke the OP_AggFinalize opcode for every aggregate function 449113449892Sdrh ** in the AggInfo structure. 4492b3bce662Sdanielk1977 */ 449313449892Sdrh static void finalizeAggFunctions(Parse *pParse, AggInfo *pAggInfo){ 449413449892Sdrh Vdbe *v = pParse->pVdbe; 449513449892Sdrh int i; 449613449892Sdrh struct AggInfo_func *pF; 449713449892Sdrh for(i=0, pF=pAggInfo->aFunc; i<pAggInfo->nFunc; i++, pF++){ 44986ab3a2ecSdanielk1977 ExprList *pList = pF->pExpr->x.pList; 44996ab3a2ecSdanielk1977 assert( !ExprHasProperty(pF->pExpr, EP_xIsSelect) ); 450066a5167bSdrh sqlite3VdbeAddOp4(v, OP_AggFinal, pF->iMem, pList ? pList->nExpr : 0, 0, 450166a5167bSdrh (void*)pF->pFunc, P4_FUNCDEF); 4502b3bce662Sdanielk1977 } 450313449892Sdrh } 450413449892Sdrh 450513449892Sdrh /* 450613449892Sdrh ** Update the accumulator memory cells for an aggregate based on 450713449892Sdrh ** the current cursor position. 450813449892Sdrh */ 450913449892Sdrh static void updateAccumulator(Parse *pParse, AggInfo *pAggInfo){ 451013449892Sdrh Vdbe *v = pParse->pVdbe; 451113449892Sdrh int i; 45127a95789cSdrh int regHit = 0; 45137a95789cSdrh int addrHitTest = 0; 451413449892Sdrh struct AggInfo_func *pF; 451513449892Sdrh struct AggInfo_col *pC; 451613449892Sdrh 451713449892Sdrh pAggInfo->directMode = 1; 451813449892Sdrh for(i=0, pF=pAggInfo->aFunc; i<pAggInfo->nFunc; i++, pF++){ 451913449892Sdrh int nArg; 4520c99130fdSdrh int addrNext = 0; 452198757157Sdrh int regAgg; 45226ab3a2ecSdanielk1977 ExprList *pList = pF->pExpr->x.pList; 45236ab3a2ecSdanielk1977 assert( !ExprHasProperty(pF->pExpr, EP_xIsSelect) ); 452413449892Sdrh if( pList ){ 452513449892Sdrh nArg = pList->nExpr; 4526892d3179Sdrh regAgg = sqlite3GetTempRange(pParse, nArg); 4527d1a01edaSdrh sqlite3ExprCodeExprList(pParse, pList, regAgg, SQLITE_ECEL_DUP); 452813449892Sdrh }else{ 452913449892Sdrh nArg = 0; 453098757157Sdrh regAgg = 0; 453113449892Sdrh } 4532c99130fdSdrh if( pF->iDistinct>=0 ){ 4533c99130fdSdrh addrNext = sqlite3VdbeMakeLabel(v); 4534c99130fdSdrh assert( nArg==1 ); 45352dcef11bSdrh codeDistinct(pParse, pF->iDistinct, addrNext, 1, regAgg); 4536c99130fdSdrh } 4537d36e1041Sdrh if( pF->pFunc->funcFlags & SQLITE_FUNC_NEEDCOLL ){ 453813449892Sdrh CollSeq *pColl = 0; 453913449892Sdrh struct ExprList_item *pItem; 454013449892Sdrh int j; 4541e82f5d04Sdrh assert( pList!=0 ); /* pList!=0 if pF->pFunc has NEEDCOLL */ 454243617e9aSdrh for(j=0, pItem=pList->a; !pColl && j<nArg; j++, pItem++){ 454313449892Sdrh pColl = sqlite3ExprCollSeq(pParse, pItem->pExpr); 454413449892Sdrh } 454513449892Sdrh if( !pColl ){ 454613449892Sdrh pColl = pParse->db->pDfltColl; 454713449892Sdrh } 45487a95789cSdrh if( regHit==0 && pAggInfo->nAccumulator ) regHit = ++pParse->nMem; 45497a95789cSdrh sqlite3VdbeAddOp4(v, OP_CollSeq, regHit, 0, 0, (char *)pColl, P4_COLLSEQ); 455013449892Sdrh } 455198757157Sdrh sqlite3VdbeAddOp4(v, OP_AggStep, 0, regAgg, pF->iMem, 455266a5167bSdrh (void*)pF->pFunc, P4_FUNCDEF); 4553ea678832Sdrh sqlite3VdbeChangeP5(v, (u8)nArg); 4554da250ea5Sdrh sqlite3ExprCacheAffinityChange(pParse, regAgg, nArg); 4555f49f3523Sdrh sqlite3ReleaseTempRange(pParse, regAgg, nArg); 4556c99130fdSdrh if( addrNext ){ 4557c99130fdSdrh sqlite3VdbeResolveLabel(v, addrNext); 4558ceea3321Sdrh sqlite3ExprCacheClear(pParse); 4559c99130fdSdrh } 456013449892Sdrh } 456167a6a40cSdan 456267a6a40cSdan /* Before populating the accumulator registers, clear the column cache. 456367a6a40cSdan ** Otherwise, if any of the required column values are already present 456467a6a40cSdan ** in registers, sqlite3ExprCode() may use OP_SCopy to copy the value 456567a6a40cSdan ** to pC->iMem. But by the time the value is used, the original register 456667a6a40cSdan ** may have been used, invalidating the underlying buffer holding the 456767a6a40cSdan ** text or blob value. See ticket [883034dcb5]. 456867a6a40cSdan ** 456967a6a40cSdan ** Another solution would be to change the OP_SCopy used to copy cached 457067a6a40cSdan ** values to an OP_Copy. 457167a6a40cSdan */ 45727a95789cSdrh if( regHit ){ 4573688852abSdrh addrHitTest = sqlite3VdbeAddOp1(v, OP_If, regHit); VdbeCoverage(v); 45747a95789cSdrh } 457567a6a40cSdan sqlite3ExprCacheClear(pParse); 457613449892Sdrh for(i=0, pC=pAggInfo->aCol; i<pAggInfo->nAccumulator; i++, pC++){ 4577389a1adbSdrh sqlite3ExprCode(pParse, pC->pExpr, pC->iMem); 457813449892Sdrh } 457913449892Sdrh pAggInfo->directMode = 0; 4580ceea3321Sdrh sqlite3ExprCacheClear(pParse); 45817a95789cSdrh if( addrHitTest ){ 45827a95789cSdrh sqlite3VdbeJumpHere(v, addrHitTest); 45837a95789cSdrh } 458413449892Sdrh } 458513449892Sdrh 4586b3bce662Sdanielk1977 /* 4587ef7075deSdan ** Add a single OP_Explain instruction to the VDBE to explain a simple 4588ef7075deSdan ** count(*) query ("SELECT count(*) FROM pTab"). 4589ef7075deSdan */ 4590ef7075deSdan #ifndef SQLITE_OMIT_EXPLAIN 4591ef7075deSdan static void explainSimpleCount( 4592ef7075deSdan Parse *pParse, /* Parse context */ 4593ef7075deSdan Table *pTab, /* Table being queried */ 4594ef7075deSdan Index *pIdx /* Index used to optimize scan, or NULL */ 4595ef7075deSdan ){ 4596ef7075deSdan if( pParse->explain==2 ){ 459748dd1d8eSdrh int bCover = (pIdx!=0 && (HasRowid(pTab) || !IsPrimaryKeyIndex(pIdx))); 45988a4380d7Sdrh char *zEqp = sqlite3MPrintf(pParse->db, "SCAN TABLE %s%s%s", 4599ef7075deSdan pTab->zName, 4600e96f2df3Sdan bCover ? " USING COVERING INDEX " : "", 4601e96f2df3Sdan bCover ? pIdx->zName : "" 4602ef7075deSdan ); 4603ef7075deSdan sqlite3VdbeAddOp4( 4604ef7075deSdan pParse->pVdbe, OP_Explain, pParse->iSelectId, 0, 0, zEqp, P4_DYNAMIC 4605ef7075deSdan ); 4606ef7075deSdan } 4607ef7075deSdan } 4608ef7075deSdan #else 4609ef7075deSdan # define explainSimpleCount(a,b,c) 4610ef7075deSdan #endif 4611ef7075deSdan 4612ef7075deSdan /* 46137d10d5a6Sdrh ** Generate code for the SELECT statement given in the p argument. 46149bb61fe7Sdrh ** 4615340309fdSdrh ** The results are returned according to the SelectDest structure. 4616340309fdSdrh ** See comments in sqliteInt.h for further information. 4617e78e8284Sdrh ** 46189bb61fe7Sdrh ** This routine returns the number of errors. If any errors are 46199bb61fe7Sdrh ** encountered, then an appropriate error message is left in 46209bb61fe7Sdrh ** pParse->zErrMsg. 46219bb61fe7Sdrh ** 46229bb61fe7Sdrh ** This routine does NOT free the Select structure passed in. The 46239bb61fe7Sdrh ** calling function needs to do that. 46249bb61fe7Sdrh */ 46254adee20fSdanielk1977 int sqlite3Select( 4626cce7d176Sdrh Parse *pParse, /* The parser context */ 46279bb61fe7Sdrh Select *p, /* The SELECT statement being coded. */ 46287d10d5a6Sdrh SelectDest *pDest /* What to do with the query results */ 4629cce7d176Sdrh ){ 463013449892Sdrh int i, j; /* Loop counters */ 463113449892Sdrh WhereInfo *pWInfo; /* Return from sqlite3WhereBegin() */ 463213449892Sdrh Vdbe *v; /* The virtual machine under construction */ 4633b3bce662Sdanielk1977 int isAgg; /* True for select lists like "count(*)" */ 4634a2e00042Sdrh ExprList *pEList; /* List of columns to extract. */ 4635ad3cab52Sdrh SrcList *pTabList; /* List of tables to select from */ 46369bb61fe7Sdrh Expr *pWhere; /* The WHERE clause. May be NULL */ 46372282792aSdrh ExprList *pGroupBy; /* The GROUP BY clause. May be NULL */ 46382282792aSdrh Expr *pHaving; /* The HAVING clause. May be NULL */ 46391d83f052Sdrh int rc = 1; /* Value to return from this function */ 4640e8e4af76Sdrh DistinctCtx sDistinct; /* Info on how to code the DISTINCT keyword */ 4641079a3072Sdrh SortCtx sSort; /* Info on how to code the ORDER BY clause */ 464213449892Sdrh AggInfo sAggInfo; /* Information used by aggregate queries */ 4643ec7429aeSdrh int iEnd; /* Address of the end of the query */ 464417435752Sdrh sqlite3 *db; /* The database connection */ 46459bb61fe7Sdrh 46462ce22453Sdan #ifndef SQLITE_OMIT_EXPLAIN 46472ce22453Sdan int iRestoreSelectId = pParse->iSelectId; 46482ce22453Sdan pParse->iSelectId = pParse->iNextSelectId++; 46492ce22453Sdan #endif 46502ce22453Sdan 465117435752Sdrh db = pParse->db; 465217435752Sdrh if( p==0 || db->mallocFailed || pParse->nErr ){ 46536f7adc8aSdrh return 1; 46546f7adc8aSdrh } 46554adee20fSdanielk1977 if( sqlite3AuthCheck(pParse, SQLITE_SELECT, 0, 0, 0) ) return 1; 465613449892Sdrh memset(&sAggInfo, 0, sizeof(sAggInfo)); 4657eb9b884cSdrh #if SELECTTRACE_ENABLED 4658eb9b884cSdrh pParse->nSelectIndent++; 4659c90713d3Sdrh SELECTTRACE(1,pParse,p, ("begin processing:\n")); 4660c90713d3Sdrh if( sqlite3SelectTrace & 0x100 ){ 4661c90713d3Sdrh sqlite3TreeViewSelect(0, p, 0); 4662c90713d3Sdrh } 4663eb9b884cSdrh #endif 4664daffd0e5Sdrh 46658e1ee88cSdrh assert( p->pOrderBy==0 || pDest->eDest!=SRT_DistFifo ); 46668e1ee88cSdrh assert( p->pOrderBy==0 || pDest->eDest!=SRT_Fifo ); 46679afccba2Sdan assert( p->pOrderBy==0 || pDest->eDest!=SRT_DistQueue ); 46689afccba2Sdan assert( p->pOrderBy==0 || pDest->eDest!=SRT_Queue ); 46696c8c8ce0Sdanielk1977 if( IgnorableOrderby(pDest) ){ 46709ed1dfa8Sdanielk1977 assert(pDest->eDest==SRT_Exists || pDest->eDest==SRT_Union || 46719afccba2Sdan pDest->eDest==SRT_Except || pDest->eDest==SRT_Discard || 46728e1ee88cSdrh pDest->eDest==SRT_Queue || pDest->eDest==SRT_DistFifo || 46738e1ee88cSdrh pDest->eDest==SRT_DistQueue || pDest->eDest==SRT_Fifo); 4674ccfcbceaSdrh /* If ORDER BY makes no difference in the output then neither does 4675ccfcbceaSdrh ** DISTINCT so it can be removed too. */ 4676ccfcbceaSdrh sqlite3ExprListDelete(db, p->pOrderBy); 4677ccfcbceaSdrh p->pOrderBy = 0; 46787d10d5a6Sdrh p->selFlags &= ~SF_Distinct; 46799a99334dSdrh } 46807d10d5a6Sdrh sqlite3SelectPrep(pParse, p, 0); 4681079a3072Sdrh memset(&sSort, 0, sizeof(sSort)); 4682079a3072Sdrh sSort.pOrderBy = p->pOrderBy; 4683b27b7f5dSdrh pTabList = p->pSrc; 4684b27b7f5dSdrh pEList = p->pEList; 4685956f4319Sdanielk1977 if( pParse->nErr || db->mallocFailed ){ 46869a99334dSdrh goto select_end; 46879a99334dSdrh } 46887d10d5a6Sdrh isAgg = (p->selFlags & SF_Aggregate)!=0; 468943152cf8Sdrh assert( pEList!=0 ); 4690cce7d176Sdrh 4691d820cb1bSdrh /* Begin generating code. 4692d820cb1bSdrh */ 46934adee20fSdanielk1977 v = sqlite3GetVdbe(pParse); 4694d820cb1bSdrh if( v==0 ) goto select_end; 4695d820cb1bSdrh 469674b617b2Sdan /* If writing to memory or generating a set 469774b617b2Sdan ** only a single column may be output. 469874b617b2Sdan */ 469974b617b2Sdan #ifndef SQLITE_OMIT_SUBQUERY 470074b617b2Sdan if( checkForMultiColumnSelectError(pParse, pDest, pEList->nExpr) ){ 470174b617b2Sdan goto select_end; 470274b617b2Sdan } 470374b617b2Sdan #endif 470474b617b2Sdan 4705d820cb1bSdrh /* Generate code for all sub-queries in the FROM clause 4706d820cb1bSdrh */ 470751522cd3Sdrh #if !defined(SQLITE_OMIT_SUBQUERY) || !defined(SQLITE_OMIT_VIEW) 4708f23329a2Sdanielk1977 for(i=0; !p->pPrior && i<pTabList->nSrc; i++){ 470913449892Sdrh struct SrcList_item *pItem = &pTabList->a[i]; 47101013c932Sdrh SelectDest dest; 4711daf79acbSdanielk1977 Select *pSub = pItem->pSelect; 4712f23329a2Sdanielk1977 int isAggSub; 4713c31c2eb8Sdrh 47145b6a9ed4Sdrh if( pSub==0 ) continue; 471521172c4cSdrh 471621172c4cSdrh /* Sometimes the code for a subquery will be generated more than 471721172c4cSdrh ** once, if the subquery is part of the WHERE clause in a LEFT JOIN, 471821172c4cSdrh ** for example. In that case, do not regenerate the code to manifest 471921172c4cSdrh ** a view or the co-routine to implement a view. The first instance 472021172c4cSdrh ** is sufficient, though the subroutine to manifest the view does need 472121172c4cSdrh ** to be invoked again. */ 47225b6a9ed4Sdrh if( pItem->addrFillSub ){ 472321172c4cSdrh if( pItem->viaCoroutine==0 ){ 47245b6a9ed4Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, pItem->regReturn, pItem->addrFillSub); 472521172c4cSdrh } 47265b6a9ed4Sdrh continue; 47275b6a9ed4Sdrh } 4728daf79acbSdanielk1977 4729fc976065Sdanielk1977 /* Increment Parse.nHeight by the height of the largest expression 4730f7b5496eSdrh ** tree referred to by this, the parent select. The child select 4731fc976065Sdanielk1977 ** may contain expression trees of at most 4732fc976065Sdanielk1977 ** (SQLITE_MAX_EXPR_DEPTH-Parse.nHeight) height. This is a bit 4733fc976065Sdanielk1977 ** more conservative than necessary, but much easier than enforcing 4734fc976065Sdanielk1977 ** an exact limit. 4735fc976065Sdanielk1977 */ 4736fc976065Sdanielk1977 pParse->nHeight += sqlite3SelectExprHeight(p); 4737daf79acbSdanielk1977 47387d10d5a6Sdrh isAggSub = (pSub->selFlags & SF_Aggregate)!=0; 4739524cc21eSdanielk1977 if( flattenSubquery(pParse, p, i, isAgg, isAggSub) ){ 47405b6a9ed4Sdrh /* This subquery can be absorbed into its parent. */ 4741f23329a2Sdanielk1977 if( isAggSub ){ 47427d10d5a6Sdrh isAgg = 1; 47437d10d5a6Sdrh p->selFlags |= SF_Aggregate; 4744daf79acbSdanielk1977 } 4745daf79acbSdanielk1977 i = -1; 4746ee06c99bSdrh }else if( pTabList->nSrc==1 4747a5759677Sdrh && OptimizationEnabled(db, SQLITE_SubqCoroutine) 4748a5759677Sdrh ){ 474921172c4cSdrh /* Implement a co-routine that will return a single row of the result 475021172c4cSdrh ** set on each invocation. 475121172c4cSdrh */ 4752725de29aSdrh int addrTop = sqlite3VdbeCurrentAddr(v)+1; 475321172c4cSdrh pItem->regReturn = ++pParse->nMem; 4754725de29aSdrh sqlite3VdbeAddOp3(v, OP_InitCoroutine, pItem->regReturn, 0, addrTop); 4755725de29aSdrh VdbeComment((v, "%s", pItem->pTab->zName)); 475621172c4cSdrh pItem->addrFillSub = addrTop; 475721172c4cSdrh sqlite3SelectDestInit(&dest, SRT_Coroutine, pItem->regReturn); 475821172c4cSdrh explainSetInteger(pItem->iSelectId, (u8)pParse->iNextSelectId); 475921172c4cSdrh sqlite3Select(pParse, pSub, &dest); 4760cfc9df76Sdan pItem->pTab->nRowLogEst = sqlite3LogEst(pSub->nSelectRow); 476121172c4cSdrh pItem->viaCoroutine = 1; 47625f612295Sdrh pItem->regResult = dest.iSdst; 476381cf13ecSdrh sqlite3VdbeAddOp1(v, OP_EndCoroutine, pItem->regReturn); 476421172c4cSdrh sqlite3VdbeJumpHere(v, addrTop-1); 476521172c4cSdrh sqlite3ClearTempRegCache(pParse); 4766daf79acbSdanielk1977 }else{ 47675b6a9ed4Sdrh /* Generate a subroutine that will fill an ephemeral table with 47685b6a9ed4Sdrh ** the content of this subquery. pItem->addrFillSub will point 47695b6a9ed4Sdrh ** to the address of the generated subroutine. pItem->regReturn 47705b6a9ed4Sdrh ** is a register allocated to hold the subroutine return address 47715b6a9ed4Sdrh */ 47727157e8eaSdrh int topAddr; 477348f2d3b1Sdrh int onceAddr = 0; 47747157e8eaSdrh int retAddr; 47755b6a9ed4Sdrh assert( pItem->addrFillSub==0 ); 47765b6a9ed4Sdrh pItem->regReturn = ++pParse->nMem; 47777157e8eaSdrh topAddr = sqlite3VdbeAddOp2(v, OP_Integer, 0, pItem->regReturn); 47787157e8eaSdrh pItem->addrFillSub = topAddr+1; 47791d8cb21fSdan if( pItem->isCorrelated==0 ){ 4780ed17167eSdrh /* If the subquery is not correlated and if we are not inside of 47815b6a9ed4Sdrh ** a trigger, then we only need to compute the value of the subquery 47825b6a9ed4Sdrh ** once. */ 47837d176105Sdrh onceAddr = sqlite3CodeOnce(pParse); VdbeCoverage(v); 4784725de29aSdrh VdbeComment((v, "materialize \"%s\"", pItem->pTab->zName)); 4785725de29aSdrh }else{ 4786725de29aSdrh VdbeNoopComment((v, "materialize \"%s\"", pItem->pTab->zName)); 47875b6a9ed4Sdrh } 47881013c932Sdrh sqlite3SelectDestInit(&dest, SRT_EphemTab, pItem->iCursor); 4789ce7e189dSdan explainSetInteger(pItem->iSelectId, (u8)pParse->iNextSelectId); 47907d10d5a6Sdrh sqlite3Select(pParse, pSub, &dest); 4791cfc9df76Sdan pItem->pTab->nRowLogEst = sqlite3LogEst(pSub->nSelectRow); 479248f2d3b1Sdrh if( onceAddr ) sqlite3VdbeJumpHere(v, onceAddr); 47937157e8eaSdrh retAddr = sqlite3VdbeAddOp1(v, OP_Return, pItem->regReturn); 47947157e8eaSdrh VdbeComment((v, "end %s", pItem->pTab->zName)); 47957157e8eaSdrh sqlite3VdbeChangeP1(v, topAddr, retAddr); 4796cdc69557Sdrh sqlite3ClearTempRegCache(pParse); 4797daf79acbSdanielk1977 } 479843152cf8Sdrh if( /*pParse->nErr ||*/ db->mallocFailed ){ 4799cfa063b3Sdrh goto select_end; 4800cfa063b3Sdrh } 4801fc976065Sdanielk1977 pParse->nHeight -= sqlite3SelectExprHeight(p); 4802832508b7Sdrh pTabList = p->pSrc; 48036c8c8ce0Sdanielk1977 if( !IgnorableOrderby(pDest) ){ 4804079a3072Sdrh sSort.pOrderBy = p->pOrderBy; 4805acd4c695Sdrh } 4806daf79acbSdanielk1977 } 4807daf79acbSdanielk1977 pEList = p->pEList; 4808daf79acbSdanielk1977 #endif 4809daf79acbSdanielk1977 pWhere = p->pWhere; 4810832508b7Sdrh pGroupBy = p->pGroupBy; 4811832508b7Sdrh pHaving = p->pHaving; 4812e8e4af76Sdrh sDistinct.isTnct = (p->selFlags & SF_Distinct)!=0; 4813832508b7Sdrh 4814f23329a2Sdanielk1977 #ifndef SQLITE_OMIT_COMPOUND_SELECT 4815f23329a2Sdanielk1977 /* If there is are a sequence of queries, do the earlier ones first. 4816f23329a2Sdanielk1977 */ 4817f23329a2Sdanielk1977 if( p->pPrior ){ 48187f61e92cSdan rc = multiSelect(pParse, p, pDest); 481917c0bc0cSdan explainSetInteger(pParse->iSelectId, iRestoreSelectId); 4820eb9b884cSdrh #if SELECTTRACE_ENABLED 4821eb9b884cSdrh SELECTTRACE(1,pParse,p,("end compound-select processing\n")); 4822eb9b884cSdrh pParse->nSelectIndent--; 4823eb9b884cSdrh #endif 48247f61e92cSdan return rc; 4825f23329a2Sdanielk1977 } 4826f23329a2Sdanielk1977 #endif 4827f23329a2Sdanielk1977 482850118cdfSdan /* If the query is DISTINCT with an ORDER BY but is not an aggregate, and 482950118cdfSdan ** if the select-list is the same as the ORDER BY list, then this query 483050118cdfSdan ** can be rewritten as a GROUP BY. In other words, this: 483150118cdfSdan ** 483250118cdfSdan ** SELECT DISTINCT xyz FROM ... ORDER BY xyz 483350118cdfSdan ** 483450118cdfSdan ** is transformed to: 483550118cdfSdan ** 483650118cdfSdan ** SELECT xyz FROM ... GROUP BY xyz 483750118cdfSdan ** 483850118cdfSdan ** The second form is preferred as a single index (or temp-table) may be 483950118cdfSdan ** used for both the ORDER BY and DISTINCT processing. As originally 484050118cdfSdan ** written the query must use a temp-table for at least one of the ORDER 484150118cdfSdan ** BY and DISTINCT, and an index or separate temp-table for the other. 484250118cdfSdan */ 484350118cdfSdan if( (p->selFlags & (SF_Distinct|SF_Aggregate))==SF_Distinct 4844079a3072Sdrh && sqlite3ExprListCompare(sSort.pOrderBy, p->pEList, -1)==0 484550118cdfSdan ){ 484650118cdfSdan p->selFlags &= ~SF_Distinct; 484750118cdfSdan p->pGroupBy = sqlite3ExprListDup(db, p->pEList, 0); 484850118cdfSdan pGroupBy = p->pGroupBy; 4849079a3072Sdrh sSort.pOrderBy = 0; 4850e8e4af76Sdrh /* Notice that even thought SF_Distinct has been cleared from p->selFlags, 4851e8e4af76Sdrh ** the sDistinct.isTnct is still set. Hence, isTnct represents the 4852e8e4af76Sdrh ** original setting of the SF_Distinct flag, not the current setting */ 4853e8e4af76Sdrh assert( sDistinct.isTnct ); 485450118cdfSdan } 485550118cdfSdan 48568b4c40d8Sdrh /* If there is an ORDER BY clause, then this sorting 48578b4c40d8Sdrh ** index might end up being unused if the data can be 48589d2985c7Sdrh ** extracted in pre-sorted order. If that is the case, then the 4859b9bb7c18Sdrh ** OP_OpenEphemeral instruction will be changed to an OP_Noop once 48609d2985c7Sdrh ** we figure out that the sorting index is not needed. The addrSortIndex 48619d2985c7Sdrh ** variable is used to facilitate that change. 48627cedc8d4Sdanielk1977 */ 4863079a3072Sdrh if( sSort.pOrderBy ){ 48640342b1f5Sdrh KeyInfo *pKeyInfo; 4865079a3072Sdrh pKeyInfo = keyInfoFromExprList(pParse, sSort.pOrderBy, 0, 0); 4866079a3072Sdrh sSort.iECursor = pParse->nTab++; 4867079a3072Sdrh sSort.addrSortIndex = 486866a5167bSdrh sqlite3VdbeAddOp4(v, OP_OpenEphemeral, 4869f45f2326Sdrh sSort.iECursor, sSort.pOrderBy->nExpr+1+pEList->nExpr, 0, 4870f45f2326Sdrh (char*)pKeyInfo, P4_KEYINFO 4871f45f2326Sdrh ); 48729d2985c7Sdrh }else{ 4873079a3072Sdrh sSort.addrSortIndex = -1; 48747cedc8d4Sdanielk1977 } 48757cedc8d4Sdanielk1977 48762d0794e3Sdrh /* If the output is destined for a temporary table, open that table. 48772d0794e3Sdrh */ 48786c8c8ce0Sdanielk1977 if( pDest->eDest==SRT_EphemTab ){ 48792b596da8Sdrh sqlite3VdbeAddOp2(v, OP_OpenEphemeral, pDest->iSDParm, pEList->nExpr); 48802d0794e3Sdrh } 48812d0794e3Sdrh 4882f42bacc2Sdrh /* Set the limiter. 4883f42bacc2Sdrh */ 4884f42bacc2Sdrh iEnd = sqlite3VdbeMakeLabel(v); 4885c63367efSdrh p->nSelectRow = LARGEST_INT64; 4886f42bacc2Sdrh computeLimitRegisters(pParse, p, iEnd); 4887079a3072Sdrh if( p->iLimit==0 && sSort.addrSortIndex>=0 ){ 4888079a3072Sdrh sqlite3VdbeGetOp(v, sSort.addrSortIndex)->opcode = OP_SorterOpen; 4889079a3072Sdrh sSort.sortFlags |= SORTFLAG_UseSorter; 4890c6aff30cSdrh } 4891f42bacc2Sdrh 4892dece1a84Sdrh /* Open a virtual index to use for the distinct set. 4893cce7d176Sdrh */ 48942ce22453Sdan if( p->selFlags & SF_Distinct ){ 4895e8e4af76Sdrh sDistinct.tabTnct = pParse->nTab++; 4896e8e4af76Sdrh sDistinct.addrTnct = sqlite3VdbeAddOp4(v, OP_OpenEphemeral, 4897e8e4af76Sdrh sDistinct.tabTnct, 0, 0, 4898079a3072Sdrh (char*)keyInfoFromExprList(pParse, p->pEList,0,0), 48992ec2fb22Sdrh P4_KEYINFO); 4900d4187c71Sdrh sqlite3VdbeChangeP5(v, BTREE_UNORDERED); 4901e8e4af76Sdrh sDistinct.eTnctType = WHERE_DISTINCT_UNORDERED; 4902832508b7Sdrh }else{ 4903e8e4af76Sdrh sDistinct.eTnctType = WHERE_DISTINCT_NOOP; 4904efb7251dSdrh } 4905832508b7Sdrh 490613449892Sdrh if( !isAgg && pGroupBy==0 ){ 4907e8e4af76Sdrh /* No aggregate functions and no GROUP BY clause */ 49086457a353Sdrh u16 wctrlFlags = (sDistinct.isTnct ? WHERE_WANT_DISTINCT : 0); 490938cc40c2Sdan 491038cc40c2Sdan /* Begin the database scan. */ 4911079a3072Sdrh pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, sSort.pOrderBy, 4912079a3072Sdrh p->pEList, wctrlFlags, 0); 49131d83f052Sdrh if( pWInfo==0 ) goto select_end; 49146f32848dSdrh if( sqlite3WhereOutputRowCount(pWInfo) < p->nSelectRow ){ 49156f32848dSdrh p->nSelectRow = sqlite3WhereOutputRowCount(pWInfo); 49166f32848dSdrh } 49176457a353Sdrh if( sDistinct.isTnct && sqlite3WhereIsDistinct(pWInfo) ){ 49186f32848dSdrh sDistinct.eTnctType = sqlite3WhereIsDistinct(pWInfo); 49196f32848dSdrh } 4920079a3072Sdrh if( sSort.pOrderBy ){ 4921079a3072Sdrh sSort.nOBSat = sqlite3WhereIsOrdered(pWInfo); 4922079a3072Sdrh if( sSort.nOBSat==sSort.pOrderBy->nExpr ){ 4923079a3072Sdrh sSort.pOrderBy = 0; 4924079a3072Sdrh } 4925079a3072Sdrh } 4926cce7d176Sdrh 4927b9bb7c18Sdrh /* If sorting index that was created by a prior OP_OpenEphemeral 4928b9bb7c18Sdrh ** instruction ended up not being needed, then change the OP_OpenEphemeral 49299d2985c7Sdrh ** into an OP_Noop. 49309d2985c7Sdrh */ 4931079a3072Sdrh if( sSort.addrSortIndex>=0 && sSort.pOrderBy==0 ){ 4932079a3072Sdrh sqlite3VdbeChangeToNoop(v, sSort.addrSortIndex); 49339d2985c7Sdrh } 49349d2985c7Sdrh 493538cc40c2Sdan /* Use the standard inner loop. */ 4936079a3072Sdrh selectInnerLoop(pParse, p, pEList, -1, &sSort, &sDistinct, pDest, 49376f32848dSdrh sqlite3WhereContinueLabel(pWInfo), 49386f32848dSdrh sqlite3WhereBreakLabel(pWInfo)); 49392282792aSdrh 4940cce7d176Sdrh /* End the database scan loop. 4941cce7d176Sdrh */ 49424adee20fSdanielk1977 sqlite3WhereEnd(pWInfo); 494313449892Sdrh }else{ 4944e8e4af76Sdrh /* This case when there exist aggregate functions or a GROUP BY clause 4945e8e4af76Sdrh ** or both */ 494613449892Sdrh NameContext sNC; /* Name context for processing aggregate information */ 494713449892Sdrh int iAMem; /* First Mem address for storing current GROUP BY */ 494813449892Sdrh int iBMem; /* First Mem address for previous GROUP BY */ 494913449892Sdrh int iUseFlag; /* Mem address holding flag indicating that at least 495013449892Sdrh ** one row of the input to the aggregator has been 495113449892Sdrh ** processed */ 495213449892Sdrh int iAbortFlag; /* Mem address which causes query abort if positive */ 495313449892Sdrh int groupBySort; /* Rows come from source in GROUP BY order */ 4954d176611bSdrh int addrEnd; /* End of processing for this SELECT */ 49551c9d835dSdrh int sortPTab = 0; /* Pseudotable used to decode sorting results */ 49561c9d835dSdrh int sortOut = 0; /* Output register from the sorter */ 4957374cd78cSdan int orderByGrp = 0; /* True if the GROUP BY and ORDER BY are the same */ 4958d176611bSdrh 4959d176611bSdrh /* Remove any and all aliases between the result set and the 4960d176611bSdrh ** GROUP BY clause. 4961d176611bSdrh */ 4962d176611bSdrh if( pGroupBy ){ 4963dc5ea5c7Sdrh int k; /* Loop counter */ 4964d176611bSdrh struct ExprList_item *pItem; /* For looping over expression in a list */ 4965d176611bSdrh 4966dc5ea5c7Sdrh for(k=p->pEList->nExpr, pItem=p->pEList->a; k>0; k--, pItem++){ 4967c2acc4e4Sdrh pItem->u.x.iAlias = 0; 4968d176611bSdrh } 4969dc5ea5c7Sdrh for(k=pGroupBy->nExpr, pItem=pGroupBy->a; k>0; k--, pItem++){ 4970c2acc4e4Sdrh pItem->u.x.iAlias = 0; 4971d176611bSdrh } 4972c63367efSdrh if( p->nSelectRow>100 ) p->nSelectRow = 100; 497395aa47b1Sdrh }else{ 4974c63367efSdrh p->nSelectRow = 1; 4975d176611bSdrh } 4976cce7d176Sdrh 497713449892Sdrh 4978374cd78cSdan /* If there is both a GROUP BY and an ORDER BY clause and they are 4979374cd78cSdan ** identical, then it may be possible to disable the ORDER BY clause 4980374cd78cSdan ** on the grounds that the GROUP BY will cause elements to come out 4981374cd78cSdan ** in the correct order. It also may not - the GROUP BY may use a 4982374cd78cSdan ** database index that causes rows to be grouped together as required 4983374cd78cSdan ** but not actually sorted. Either way, record the fact that the 4984374cd78cSdan ** ORDER BY and GROUP BY clauses are the same by setting the orderByGrp 4985374cd78cSdan ** variable. */ 4986374cd78cSdan if( sqlite3ExprListCompare(pGroupBy, sSort.pOrderBy, -1)==0 ){ 4987374cd78cSdan orderByGrp = 1; 4988374cd78cSdan } 4989374cd78cSdan 4990d176611bSdrh /* Create a label to jump to when we want to abort the query */ 499113449892Sdrh addrEnd = sqlite3VdbeMakeLabel(v); 499213449892Sdrh 499313449892Sdrh /* Convert TK_COLUMN nodes into TK_AGG_COLUMN and make entries in 499413449892Sdrh ** sAggInfo for all TK_AGG_FUNCTION nodes in expressions of the 499513449892Sdrh ** SELECT statement. 49962282792aSdrh */ 499713449892Sdrh memset(&sNC, 0, sizeof(sNC)); 499813449892Sdrh sNC.pParse = pParse; 499913449892Sdrh sNC.pSrcList = pTabList; 500013449892Sdrh sNC.pAggInfo = &sAggInfo; 50017e61d18eSdrh sAggInfo.mnReg = pParse->nMem+1; 5002dd23c6bfSdan sAggInfo.nSortingColumn = pGroupBy ? pGroupBy->nExpr : 0; 50039d2985c7Sdrh sAggInfo.pGroupBy = pGroupBy; 5004d2b3e23bSdrh sqlite3ExprAnalyzeAggList(&sNC, pEList); 5005079a3072Sdrh sqlite3ExprAnalyzeAggList(&sNC, sSort.pOrderBy); 5006d2b3e23bSdrh if( pHaving ){ 5007d2b3e23bSdrh sqlite3ExprAnalyzeAggregates(&sNC, pHaving); 500813449892Sdrh } 500913449892Sdrh sAggInfo.nAccumulator = sAggInfo.nColumn; 501013449892Sdrh for(i=0; i<sAggInfo.nFunc; i++){ 50116ab3a2ecSdanielk1977 assert( !ExprHasProperty(sAggInfo.aFunc[i].pExpr, EP_xIsSelect) ); 50123a8c4be7Sdrh sNC.ncFlags |= NC_InAggFunc; 50136ab3a2ecSdanielk1977 sqlite3ExprAnalyzeAggList(&sNC, sAggInfo.aFunc[i].pExpr->x.pList); 50143a8c4be7Sdrh sNC.ncFlags &= ~NC_InAggFunc; 501513449892Sdrh } 50167e61d18eSdrh sAggInfo.mxReg = pParse->nMem; 501717435752Sdrh if( db->mallocFailed ) goto select_end; 501813449892Sdrh 501913449892Sdrh /* Processing for aggregates with GROUP BY is very different and 50203c4809a2Sdanielk1977 ** much more complex than aggregates without a GROUP BY. 502113449892Sdrh */ 502213449892Sdrh if( pGroupBy ){ 502313449892Sdrh KeyInfo *pKeyInfo; /* Keying information for the group by clause */ 5024d176611bSdrh int j1; /* A-vs-B comparision jump */ 5025d176611bSdrh int addrOutputRow; /* Start of subroutine that outputs a result row */ 5026d176611bSdrh int regOutputRow; /* Return address register for output subroutine */ 5027d176611bSdrh int addrSetAbort; /* Set the abort flag and return */ 5028d176611bSdrh int addrTopOfLoop; /* Top of the input loop */ 5029d176611bSdrh int addrSortingIdx; /* The OP_OpenEphemeral for the sorting index */ 5030d176611bSdrh int addrReset; /* Subroutine for resetting the accumulator */ 5031d176611bSdrh int regReset; /* Return address register for reset subroutine */ 503213449892Sdrh 503313449892Sdrh /* If there is a GROUP BY clause we might need a sorting index to 503413449892Sdrh ** implement it. Allocate that sorting index now. If it turns out 50351c9d835dSdrh ** that we do not need it after all, the OP_SorterOpen instruction 503613449892Sdrh ** will be converted into a Noop. 503713449892Sdrh */ 503813449892Sdrh sAggInfo.sortingIdx = pParse->nTab++; 5039079a3072Sdrh pKeyInfo = keyInfoFromExprList(pParse, pGroupBy, 0, 0); 50401c9d835dSdrh addrSortingIdx = sqlite3VdbeAddOp4(v, OP_SorterOpen, 5041cd3e8f7cSdanielk1977 sAggInfo.sortingIdx, sAggInfo.nSortingColumn, 50422ec2fb22Sdrh 0, (char*)pKeyInfo, P4_KEYINFO); 504313449892Sdrh 504413449892Sdrh /* Initialize memory locations used by GROUP BY aggregate processing 504513449892Sdrh */ 50460a07c107Sdrh iUseFlag = ++pParse->nMem; 50470a07c107Sdrh iAbortFlag = ++pParse->nMem; 5048d176611bSdrh regOutputRow = ++pParse->nMem; 5049d176611bSdrh addrOutputRow = sqlite3VdbeMakeLabel(v); 5050d176611bSdrh regReset = ++pParse->nMem; 5051d176611bSdrh addrReset = sqlite3VdbeMakeLabel(v); 50520a07c107Sdrh iAMem = pParse->nMem + 1; 505313449892Sdrh pParse->nMem += pGroupBy->nExpr; 50540a07c107Sdrh iBMem = pParse->nMem + 1; 505513449892Sdrh pParse->nMem += pGroupBy->nExpr; 50564c583128Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 0, iAbortFlag); 5057d4e70ebdSdrh VdbeComment((v, "clear abort flag")); 50584c583128Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 0, iUseFlag); 5059d4e70ebdSdrh VdbeComment((v, "indicate accumulator empty")); 5060b8475df8Sdrh sqlite3VdbeAddOp3(v, OP_Null, 0, iAMem, iAMem+pGroupBy->nExpr-1); 5061e313382eSdrh 506213449892Sdrh /* Begin a loop that will extract all source rows in GROUP BY order. 506313449892Sdrh ** This might involve two separate loops with an OP_Sort in between, or 506413449892Sdrh ** it might be a single loop that uses an index to extract information 506513449892Sdrh ** in the right order to begin with. 506613449892Sdrh */ 50672eb95377Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, regReset, addrReset); 506893ec45d5Sdrh pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pGroupBy, 0, 5069374cd78cSdan WHERE_GROUPBY | (orderByGrp ? WHERE_SORTBYGROUP : 0), 0 5070374cd78cSdan ); 50715360ad34Sdrh if( pWInfo==0 ) goto select_end; 5072ddba0c22Sdrh if( sqlite3WhereIsOrdered(pWInfo)==pGroupBy->nExpr ){ 507313449892Sdrh /* The optimizer is able to deliver rows in group by order so 5074b9bb7c18Sdrh ** we do not have to sort. The OP_OpenEphemeral table will be 507513449892Sdrh ** cancelled later because we still need to use the pKeyInfo 507613449892Sdrh */ 507713449892Sdrh groupBySort = 0; 507813449892Sdrh }else{ 507913449892Sdrh /* Rows are coming out in undetermined order. We have to push 508013449892Sdrh ** each row into a sorting index, terminate the first loop, 508113449892Sdrh ** then loop over the sorting index in order to get the output 508213449892Sdrh ** in sorted order 508313449892Sdrh */ 5084892d3179Sdrh int regBase; 5085892d3179Sdrh int regRecord; 5086892d3179Sdrh int nCol; 5087892d3179Sdrh int nGroupBy; 5088892d3179Sdrh 50892ce22453Sdan explainTempTable(pParse, 5090e8e4af76Sdrh (sDistinct.isTnct && (p->selFlags&SF_Distinct)==0) ? 5091e8e4af76Sdrh "DISTINCT" : "GROUP BY"); 50922ce22453Sdan 509313449892Sdrh groupBySort = 1; 5094892d3179Sdrh nGroupBy = pGroupBy->nExpr; 5095dd23c6bfSdan nCol = nGroupBy; 5096dd23c6bfSdan j = nGroupBy; 509713449892Sdrh for(i=0; i<sAggInfo.nColumn; i++){ 5098892d3179Sdrh if( sAggInfo.aCol[i].iSorterColumn>=j ){ 5099892d3179Sdrh nCol++; 510013449892Sdrh j++; 510113449892Sdrh } 5102892d3179Sdrh } 5103892d3179Sdrh regBase = sqlite3GetTempRange(pParse, nCol); 5104ceea3321Sdrh sqlite3ExprCacheClear(pParse); 5105191b54cbSdrh sqlite3ExprCodeExprList(pParse, pGroupBy, regBase, 0); 5106dd23c6bfSdan j = nGroupBy; 5107892d3179Sdrh for(i=0; i<sAggInfo.nColumn; i++){ 5108892d3179Sdrh struct AggInfo_col *pCol = &sAggInfo.aCol[i]; 5109892d3179Sdrh if( pCol->iSorterColumn>=j ){ 5110e55cbd72Sdrh int r1 = j + regBase; 51116a012f04Sdrh int r2; 5112701bb3b4Sdrh 51136a012f04Sdrh r2 = sqlite3ExprCodeGetColumn(pParse, 5114a748fdccSdrh pCol->pTab, pCol->iColumn, pCol->iTable, r1, 0); 51156a012f04Sdrh if( r1!=r2 ){ 51166a012f04Sdrh sqlite3VdbeAddOp2(v, OP_SCopy, r2, r1); 51176a012f04Sdrh } 51186a012f04Sdrh j++; 5119892d3179Sdrh } 5120892d3179Sdrh } 5121892d3179Sdrh regRecord = sqlite3GetTempReg(pParse); 51221db639ceSdrh sqlite3VdbeAddOp3(v, OP_MakeRecord, regBase, nCol, regRecord); 51231c9d835dSdrh sqlite3VdbeAddOp2(v, OP_SorterInsert, sAggInfo.sortingIdx, regRecord); 5124892d3179Sdrh sqlite3ReleaseTempReg(pParse, regRecord); 5125892d3179Sdrh sqlite3ReleaseTempRange(pParse, regBase, nCol); 512613449892Sdrh sqlite3WhereEnd(pWInfo); 51275134d135Sdan sAggInfo.sortingIdxPTab = sortPTab = pParse->nTab++; 51281c9d835dSdrh sortOut = sqlite3GetTempReg(pParse); 51291c9d835dSdrh sqlite3VdbeAddOp3(v, OP_OpenPseudo, sortPTab, sortOut, nCol); 51301c9d835dSdrh sqlite3VdbeAddOp2(v, OP_SorterSort, sAggInfo.sortingIdx, addrEnd); 5131688852abSdrh VdbeComment((v, "GROUP BY sort")); VdbeCoverage(v); 513213449892Sdrh sAggInfo.useSortingIdx = 1; 5133ceea3321Sdrh sqlite3ExprCacheClear(pParse); 5134374cd78cSdan 5135374cd78cSdan } 5136374cd78cSdan 5137374cd78cSdan /* If the index or temporary table used by the GROUP BY sort 5138374cd78cSdan ** will naturally deliver rows in the order required by the ORDER BY 5139374cd78cSdan ** clause, cancel the ephemeral table open coded earlier. 5140374cd78cSdan ** 5141374cd78cSdan ** This is an optimization - the correct answer should result regardless. 5142374cd78cSdan ** Use the SQLITE_GroupByOrder flag with SQLITE_TESTCTRL_OPTIMIZER to 5143374cd78cSdan ** disable this optimization for testing purposes. */ 5144374cd78cSdan if( orderByGrp && OptimizationEnabled(db, SQLITE_GroupByOrder) 5145374cd78cSdan && (groupBySort || sqlite3WhereIsSorted(pWInfo)) 5146374cd78cSdan ){ 5147374cd78cSdan sSort.pOrderBy = 0; 5148374cd78cSdan sqlite3VdbeChangeToNoop(v, sSort.addrSortIndex); 514913449892Sdrh } 515013449892Sdrh 515113449892Sdrh /* Evaluate the current GROUP BY terms and store in b0, b1, b2... 515213449892Sdrh ** (b0 is memory location iBMem+0, b1 is iBMem+1, and so forth) 515313449892Sdrh ** Then compare the current GROUP BY terms against the GROUP BY terms 515413449892Sdrh ** from the previous row currently stored in a0, a1, a2... 515513449892Sdrh */ 515613449892Sdrh addrTopOfLoop = sqlite3VdbeCurrentAddr(v); 5157ceea3321Sdrh sqlite3ExprCacheClear(pParse); 51581c9d835dSdrh if( groupBySort ){ 51591c9d835dSdrh sqlite3VdbeAddOp2(v, OP_SorterData, sAggInfo.sortingIdx, sortOut); 51601c9d835dSdrh } 516113449892Sdrh for(j=0; j<pGroupBy->nExpr; j++){ 516213449892Sdrh if( groupBySort ){ 51631c9d835dSdrh sqlite3VdbeAddOp3(v, OP_Column, sortPTab, j, iBMem+j); 51641c9d835dSdrh if( j==0 ) sqlite3VdbeChangeP5(v, OPFLAG_CLEARCACHE); 516513449892Sdrh }else{ 516613449892Sdrh sAggInfo.directMode = 1; 51672dcef11bSdrh sqlite3ExprCode(pParse, pGroupBy->a[j].pExpr, iBMem+j); 516813449892Sdrh } 516913449892Sdrh } 517016ee60ffSdrh sqlite3VdbeAddOp4(v, OP_Compare, iAMem, iBMem, pGroupBy->nExpr, 51712ec2fb22Sdrh (char*)sqlite3KeyInfoRef(pKeyInfo), P4_KEYINFO); 517216ee60ffSdrh j1 = sqlite3VdbeCurrentAddr(v); 5173688852abSdrh sqlite3VdbeAddOp3(v, OP_Jump, j1+1, 0, j1+1); VdbeCoverage(v); 517413449892Sdrh 517513449892Sdrh /* Generate code that runs whenever the GROUP BY changes. 5176e00ee6ebSdrh ** Changes in the GROUP BY are detected by the previous code 517713449892Sdrh ** block. If there were no changes, this block is skipped. 517813449892Sdrh ** 517913449892Sdrh ** This code copies current group by terms in b0,b1,b2,... 518013449892Sdrh ** over to a0,a1,a2. It then calls the output subroutine 518113449892Sdrh ** and resets the aggregate accumulator registers in preparation 518213449892Sdrh ** for the next GROUP BY batch. 518313449892Sdrh */ 5184b21e7c70Sdrh sqlite3ExprCodeMove(pParse, iBMem, iAMem, pGroupBy->nExpr); 51852eb95377Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, regOutputRow, addrOutputRow); 5186d4e70ebdSdrh VdbeComment((v, "output one row")); 5187688852abSdrh sqlite3VdbeAddOp2(v, OP_IfPos, iAbortFlag, addrEnd); VdbeCoverage(v); 5188d4e70ebdSdrh VdbeComment((v, "check abort flag")); 51892eb95377Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, regReset, addrReset); 5190d4e70ebdSdrh VdbeComment((v, "reset accumulator")); 519113449892Sdrh 519213449892Sdrh /* Update the aggregate accumulators based on the content of 519313449892Sdrh ** the current row 519413449892Sdrh */ 519516ee60ffSdrh sqlite3VdbeJumpHere(v, j1); 519613449892Sdrh updateAccumulator(pParse, &sAggInfo); 51974c583128Sdrh sqlite3VdbeAddOp2(v, OP_Integer, 1, iUseFlag); 5198d4e70ebdSdrh VdbeComment((v, "indicate data in accumulator")); 519913449892Sdrh 520013449892Sdrh /* End of the loop 520113449892Sdrh */ 520213449892Sdrh if( groupBySort ){ 52031c9d835dSdrh sqlite3VdbeAddOp2(v, OP_SorterNext, sAggInfo.sortingIdx, addrTopOfLoop); 5204688852abSdrh VdbeCoverage(v); 520513449892Sdrh }else{ 520613449892Sdrh sqlite3WhereEnd(pWInfo); 520748f2d3b1Sdrh sqlite3VdbeChangeToNoop(v, addrSortingIdx); 520813449892Sdrh } 520913449892Sdrh 521013449892Sdrh /* Output the final row of result 521113449892Sdrh */ 52122eb95377Sdrh sqlite3VdbeAddOp2(v, OP_Gosub, regOutputRow, addrOutputRow); 5213d4e70ebdSdrh VdbeComment((v, "output final row")); 521413449892Sdrh 5215d176611bSdrh /* Jump over the subroutines 5216d176611bSdrh */ 5217d176611bSdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, addrEnd); 5218d176611bSdrh 5219d176611bSdrh /* Generate a subroutine that outputs a single row of the result 5220d176611bSdrh ** set. This subroutine first looks at the iUseFlag. If iUseFlag 5221d176611bSdrh ** is less than or equal to zero, the subroutine is a no-op. If 5222d176611bSdrh ** the processing calls for the query to abort, this subroutine 5223d176611bSdrh ** increments the iAbortFlag memory location before returning in 5224d176611bSdrh ** order to signal the caller to abort. 5225d176611bSdrh */ 5226d176611bSdrh addrSetAbort = sqlite3VdbeCurrentAddr(v); 5227d176611bSdrh sqlite3VdbeAddOp2(v, OP_Integer, 1, iAbortFlag); 5228d176611bSdrh VdbeComment((v, "set abort flag")); 5229d176611bSdrh sqlite3VdbeAddOp1(v, OP_Return, regOutputRow); 5230d176611bSdrh sqlite3VdbeResolveLabel(v, addrOutputRow); 5231d176611bSdrh addrOutputRow = sqlite3VdbeCurrentAddr(v); 5232688852abSdrh sqlite3VdbeAddOp2(v, OP_IfPos, iUseFlag, addrOutputRow+2); VdbeCoverage(v); 5233d176611bSdrh VdbeComment((v, "Groupby result generator entry point")); 5234d176611bSdrh sqlite3VdbeAddOp1(v, OP_Return, regOutputRow); 5235d176611bSdrh finalizeAggFunctions(pParse, &sAggInfo); 5236d176611bSdrh sqlite3ExprIfFalse(pParse, pHaving, addrOutputRow+1, SQLITE_JUMPIFNULL); 5237079a3072Sdrh selectInnerLoop(pParse, p, p->pEList, -1, &sSort, 5238e8e4af76Sdrh &sDistinct, pDest, 5239d176611bSdrh addrOutputRow+1, addrSetAbort); 5240d176611bSdrh sqlite3VdbeAddOp1(v, OP_Return, regOutputRow); 5241d176611bSdrh VdbeComment((v, "end groupby result generator")); 5242d176611bSdrh 5243d176611bSdrh /* Generate a subroutine that will reset the group-by accumulator 5244d176611bSdrh */ 5245d176611bSdrh sqlite3VdbeResolveLabel(v, addrReset); 5246d176611bSdrh resetAccumulator(pParse, &sAggInfo); 5247d176611bSdrh sqlite3VdbeAddOp1(v, OP_Return, regReset); 5248d176611bSdrh 524943152cf8Sdrh } /* endif pGroupBy. Begin aggregate queries without GROUP BY: */ 525013449892Sdrh else { 5251dba0137eSdanielk1977 ExprList *pDel = 0; 5252a5533162Sdanielk1977 #ifndef SQLITE_OMIT_BTREECOUNT 5253a5533162Sdanielk1977 Table *pTab; 5254a5533162Sdanielk1977 if( (pTab = isSimpleCount(p, &sAggInfo))!=0 ){ 5255a5533162Sdanielk1977 /* If isSimpleCount() returns a pointer to a Table structure, then 5256a5533162Sdanielk1977 ** the SQL statement is of the form: 5257a5533162Sdanielk1977 ** 5258a5533162Sdanielk1977 ** SELECT count(*) FROM <tbl> 5259a5533162Sdanielk1977 ** 5260a5533162Sdanielk1977 ** where the Table structure returned represents table <tbl>. 5261a5533162Sdanielk1977 ** 5262a5533162Sdanielk1977 ** This statement is so common that it is optimized specially. The 5263a5533162Sdanielk1977 ** OP_Count instruction is executed either on the intkey table that 5264a5533162Sdanielk1977 ** contains the data for table <tbl> or on one of its indexes. It 5265a5533162Sdanielk1977 ** is better to execute the op on an index, as indexes are almost 5266a5533162Sdanielk1977 ** always spread across less pages than their corresponding tables. 5267a5533162Sdanielk1977 */ 5268a5533162Sdanielk1977 const int iDb = sqlite3SchemaToIndex(pParse->db, pTab->pSchema); 5269a5533162Sdanielk1977 const int iCsr = pParse->nTab++; /* Cursor to scan b-tree */ 5270a5533162Sdanielk1977 Index *pIdx; /* Iterator variable */ 5271a5533162Sdanielk1977 KeyInfo *pKeyInfo = 0; /* Keyinfo for scanned index */ 5272a5533162Sdanielk1977 Index *pBest = 0; /* Best index found so far */ 5273a5533162Sdanielk1977 int iRoot = pTab->tnum; /* Root page of scanned b-tree */ 5274a9d1ccb9Sdanielk1977 5275a5533162Sdanielk1977 sqlite3CodeVerifySchema(pParse, iDb); 5276a5533162Sdanielk1977 sqlite3TableLock(pParse, iDb, pTab->tnum, 0, pTab->zName); 5277a5533162Sdanielk1977 5278d9e3cad2Sdrh /* Search for the index that has the lowest scan cost. 5279a5533162Sdanielk1977 ** 52803e9548b3Sdrh ** (2011-04-15) Do not do a full scan of an unordered index. 52813e9548b3Sdrh ** 5282abcc1941Sdrh ** (2013-10-03) Do not count the entries in a partial index. 52835f33f375Sdrh ** 5284a5533162Sdanielk1977 ** In practice the KeyInfo structure will not be used. It is only 5285a5533162Sdanielk1977 ** passed to keep OP_OpenRead happy. 5286a5533162Sdanielk1977 */ 52875c7917e4Sdrh if( !HasRowid(pTab) ) pBest = sqlite3PrimaryKeyIndex(pTab); 5288a5533162Sdanielk1977 for(pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext){ 5289d9e3cad2Sdrh if( pIdx->bUnordered==0 5290e13e9f54Sdrh && pIdx->szIdxRow<pTab->szTabRow 5291d3037a41Sdrh && pIdx->pPartIdxWhere==0 5292e13e9f54Sdrh && (!pBest || pIdx->szIdxRow<pBest->szIdxRow) 5293d9e3cad2Sdrh ){ 5294a5533162Sdanielk1977 pBest = pIdx; 5295a5533162Sdanielk1977 } 5296a5533162Sdanielk1977 } 5297d9e3cad2Sdrh if( pBest ){ 5298a5533162Sdanielk1977 iRoot = pBest->tnum; 52992ec2fb22Sdrh pKeyInfo = sqlite3KeyInfoOfIndex(pParse, pBest); 5300a5533162Sdanielk1977 } 5301a5533162Sdanielk1977 5302a5533162Sdanielk1977 /* Open a read-only cursor, execute the OP_Count, close the cursor. */ 5303261c02d9Sdrh sqlite3VdbeAddOp4Int(v, OP_OpenRead, iCsr, iRoot, iDb, 1); 5304a5533162Sdanielk1977 if( pKeyInfo ){ 53052ec2fb22Sdrh sqlite3VdbeChangeP4(v, -1, (char *)pKeyInfo, P4_KEYINFO); 5306a5533162Sdanielk1977 } 5307a5533162Sdanielk1977 sqlite3VdbeAddOp2(v, OP_Count, iCsr, sAggInfo.aFunc[0].iMem); 5308a5533162Sdanielk1977 sqlite3VdbeAddOp1(v, OP_Close, iCsr); 5309ef7075deSdan explainSimpleCount(pParse, pTab, pBest); 5310a5533162Sdanielk1977 }else 5311a5533162Sdanielk1977 #endif /* SQLITE_OMIT_BTREECOUNT */ 5312a5533162Sdanielk1977 { 5313738bdcfbSdanielk1977 /* Check if the query is of one of the following forms: 5314738bdcfbSdanielk1977 ** 5315738bdcfbSdanielk1977 ** SELECT min(x) FROM ... 5316738bdcfbSdanielk1977 ** SELECT max(x) FROM ... 5317738bdcfbSdanielk1977 ** 5318738bdcfbSdanielk1977 ** If it is, then ask the code in where.c to attempt to sort results 5319738bdcfbSdanielk1977 ** as if there was an "ORDER ON x" or "ORDER ON x DESC" clause. 5320738bdcfbSdanielk1977 ** If where.c is able to produce results sorted in this order, then 5321738bdcfbSdanielk1977 ** add vdbe code to break out of the processing loop after the 5322738bdcfbSdanielk1977 ** first iteration (since the first iteration of the loop is 5323738bdcfbSdanielk1977 ** guaranteed to operate on the row with the minimum or maximum 5324738bdcfbSdanielk1977 ** value of x, the only row required). 5325738bdcfbSdanielk1977 ** 5326738bdcfbSdanielk1977 ** A special flag must be passed to sqlite3WhereBegin() to slightly 532748864df9Smistachkin ** modify behavior as follows: 5328738bdcfbSdanielk1977 ** 5329738bdcfbSdanielk1977 ** + If the query is a "SELECT min(x)", then the loop coded by 5330738bdcfbSdanielk1977 ** where.c should not iterate over any values with a NULL value 5331738bdcfbSdanielk1977 ** for x. 5332738bdcfbSdanielk1977 ** 5333738bdcfbSdanielk1977 ** + The optimizer code in where.c (the thing that decides which 5334738bdcfbSdanielk1977 ** index or indices to use) should place a different priority on 5335738bdcfbSdanielk1977 ** satisfying the 'ORDER BY' clause than it does in other cases. 5336738bdcfbSdanielk1977 ** Refer to code and comments in where.c for details. 5337738bdcfbSdanielk1977 */ 5338a5533162Sdanielk1977 ExprList *pMinMax = 0; 53394ac391fcSdan u8 flag = WHERE_ORDERBY_NORMAL; 53404ac391fcSdan 53414ac391fcSdan assert( p->pGroupBy==0 ); 53424ac391fcSdan assert( flag==0 ); 53434ac391fcSdan if( p->pHaving==0 ){ 53444ac391fcSdan flag = minMaxQuery(&sAggInfo, &pMinMax); 53454ac391fcSdan } 53464ac391fcSdan assert( flag==0 || (pMinMax!=0 && pMinMax->nExpr==1) ); 53474ac391fcSdan 5348a9d1ccb9Sdanielk1977 if( flag ){ 53494ac391fcSdan pMinMax = sqlite3ExprListDup(db, pMinMax, 0); 53506ab3a2ecSdanielk1977 pDel = pMinMax; 53510e359b30Sdrh if( pMinMax && !db->mallocFailed ){ 5352ea678832Sdrh pMinMax->a[0].sortOrder = flag!=WHERE_ORDERBY_MIN ?1:0; 5353a9d1ccb9Sdanielk1977 pMinMax->a[0].pExpr->op = TK_COLUMN; 5354a9d1ccb9Sdanielk1977 } 53551013c932Sdrh } 5356a9d1ccb9Sdanielk1977 535713449892Sdrh /* This case runs if the aggregate has no GROUP BY clause. The 535813449892Sdrh ** processing is much simpler since there is only a single row 535913449892Sdrh ** of output. 536013449892Sdrh */ 536113449892Sdrh resetAccumulator(pParse, &sAggInfo); 536246ec5b63Sdrh pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, pMinMax,0,flag,0); 5363dba0137eSdanielk1977 if( pWInfo==0 ){ 5364633e6d57Sdrh sqlite3ExprListDelete(db, pDel); 5365dba0137eSdanielk1977 goto select_end; 5366dba0137eSdanielk1977 } 536713449892Sdrh updateAccumulator(pParse, &sAggInfo); 536846c35f9bSdrh assert( pMinMax==0 || pMinMax->nExpr==1 ); 5369ddba0c22Sdrh if( sqlite3WhereIsOrdered(pWInfo)>0 ){ 53706f32848dSdrh sqlite3VdbeAddOp2(v, OP_Goto, 0, sqlite3WhereBreakLabel(pWInfo)); 5371a5533162Sdanielk1977 VdbeComment((v, "%s() by index", 5372a5533162Sdanielk1977 (flag==WHERE_ORDERBY_MIN?"min":"max"))); 5373a9d1ccb9Sdanielk1977 } 537413449892Sdrh sqlite3WhereEnd(pWInfo); 537513449892Sdrh finalizeAggFunctions(pParse, &sAggInfo); 53767a895a80Sdanielk1977 } 53777a895a80Sdanielk1977 5378079a3072Sdrh sSort.pOrderBy = 0; 537935573356Sdrh sqlite3ExprIfFalse(pParse, pHaving, addrEnd, SQLITE_JUMPIFNULL); 5380079a3072Sdrh selectInnerLoop(pParse, p, p->pEList, -1, 0, 0, 5381a9671a22Sdrh pDest, addrEnd, addrEnd); 5382633e6d57Sdrh sqlite3ExprListDelete(db, pDel); 538313449892Sdrh } 538413449892Sdrh sqlite3VdbeResolveLabel(v, addrEnd); 538513449892Sdrh 538613449892Sdrh } /* endif aggregate query */ 53872282792aSdrh 5388e8e4af76Sdrh if( sDistinct.eTnctType==WHERE_DISTINCT_UNORDERED ){ 53892ce22453Sdan explainTempTable(pParse, "DISTINCT"); 53902ce22453Sdan } 53912ce22453Sdan 5392cce7d176Sdrh /* If there is an ORDER BY clause, then we need to sort the results 5393cce7d176Sdrh ** and send them to the callback one by one. 5394cce7d176Sdrh */ 5395079a3072Sdrh if( sSort.pOrderBy ){ 53966284db90Sdrh explainTempTable(pParse, sSort.nOBSat>0 ? "RIGHT PART OF ORDER BY":"ORDER BY"); 5397079a3072Sdrh generateSortTail(pParse, p, &sSort, pEList->nExpr, pDest); 5398cce7d176Sdrh } 53996a535340Sdrh 5400ec7429aeSdrh /* Jump here to skip this query 5401ec7429aeSdrh */ 5402ec7429aeSdrh sqlite3VdbeResolveLabel(v, iEnd); 5403ec7429aeSdrh 54041d83f052Sdrh /* The SELECT was successfully coded. Set the return code to 0 54051d83f052Sdrh ** to indicate no errors. 54061d83f052Sdrh */ 54071d83f052Sdrh rc = 0; 54081d83f052Sdrh 54091d83f052Sdrh /* Control jumps to here if an error is encountered above, or upon 54101d83f052Sdrh ** successful coding of the SELECT. 54111d83f052Sdrh */ 54121d83f052Sdrh select_end: 541317c0bc0cSdan explainSetInteger(pParse->iSelectId, iRestoreSelectId); 5414955de52cSdanielk1977 54157d10d5a6Sdrh /* Identify column names if results of the SELECT are to be output. 5416955de52cSdanielk1977 */ 54177d10d5a6Sdrh if( rc==SQLITE_OK && pDest->eDest==SRT_Output ){ 5418955de52cSdanielk1977 generateColumnNames(pParse, pTabList, pEList); 5419955de52cSdanielk1977 } 5420955de52cSdanielk1977 5421633e6d57Sdrh sqlite3DbFree(db, sAggInfo.aCol); 5422633e6d57Sdrh sqlite3DbFree(db, sAggInfo.aFunc); 5423eb9b884cSdrh #if SELECTTRACE_ENABLED 5424eb9b884cSdrh SELECTTRACE(1,pParse,p,("end processing\n")); 5425eb9b884cSdrh pParse->nSelectIndent--; 5426eb9b884cSdrh #endif 54271d83f052Sdrh return rc; 5428cce7d176Sdrh } 5429485f0039Sdrh 54304fa4a54fSdrh #ifdef SQLITE_DEBUG 5431485f0039Sdrh /* 54327e02e5e6Sdrh ** Generate a human-readable description of a the Select object. 5433485f0039Sdrh */ 54344fa4a54fSdrh void sqlite3TreeViewSelect(TreeView *pView, const Select *p, u8 moreToFollow){ 5435*b08cd3f3Sdrh int n = 0; 54364fa4a54fSdrh pView = sqlite3TreeViewPush(pView, moreToFollow); 54374fa4a54fSdrh sqlite3TreeViewLine(pView, "SELECT%s%s", 54384fa4a54fSdrh ((p->selFlags & SF_Distinct) ? " DISTINCT" : ""), 54394fa4a54fSdrh ((p->selFlags & SF_Aggregate) ? " agg_flag" : "") 54404fa4a54fSdrh ); 5441*b08cd3f3Sdrh if( p->pSrc && p->pSrc->nSrc ) n++; 5442*b08cd3f3Sdrh if( p->pWhere ) n++; 5443*b08cd3f3Sdrh if( p->pGroupBy ) n++; 5444*b08cd3f3Sdrh if( p->pHaving ) n++; 5445*b08cd3f3Sdrh if( p->pOrderBy ) n++; 5446*b08cd3f3Sdrh if( p->pLimit ) n++; 5447*b08cd3f3Sdrh if( p->pOffset ) n++; 5448*b08cd3f3Sdrh if( p->pPrior ) n++; 5449*b08cd3f3Sdrh sqlite3TreeViewExprList(pView, p->pEList, (n--)>0, "result-set"); 54507e02e5e6Sdrh if( p->pSrc && p->pSrc->nSrc ){ 5451485f0039Sdrh int i; 5452*b08cd3f3Sdrh pView = sqlite3TreeViewPush(pView, (n--)>0); 54534fa4a54fSdrh sqlite3TreeViewLine(pView, "FROM"); 5454485f0039Sdrh for(i=0; i<p->pSrc->nSrc; i++){ 5455485f0039Sdrh struct SrcList_item *pItem = &p->pSrc->a[i]; 54564fa4a54fSdrh StrAccum x; 54574fa4a54fSdrh char zLine[100]; 54584fa4a54fSdrh sqlite3StrAccumInit(&x, zLine, sizeof(zLine), 0); 54594fa4a54fSdrh sqlite3XPrintf(&x, 0, "{%d,*}", pItem->iCursor); 54604fa4a54fSdrh if( pItem->zDatabase ){ 54614fa4a54fSdrh sqlite3XPrintf(&x, 0, " %s.%s", pItem->zDatabase, pItem->zName); 5462485f0039Sdrh }else if( pItem->zName ){ 54634fa4a54fSdrh sqlite3XPrintf(&x, 0, " %s", pItem->zName); 54644fa4a54fSdrh } 54654fa4a54fSdrh if( pItem->pTab ){ 54664fa4a54fSdrh sqlite3XPrintf(&x, 0, " tabname=%Q", pItem->pTab->zName); 5467485f0039Sdrh } 5468485f0039Sdrh if( pItem->zAlias ){ 54694fa4a54fSdrh sqlite3XPrintf(&x, 0, " (AS %s)", pItem->zAlias); 5470485f0039Sdrh } 5471a84203a0Sdrh if( pItem->jointype & JT_LEFT ){ 54724fa4a54fSdrh sqlite3XPrintf(&x, 0, " LEFT-JOIN"); 5473485f0039Sdrh } 54744fa4a54fSdrh sqlite3StrAccumFinish(&x); 54754fa4a54fSdrh sqlite3TreeViewItem(pView, zLine, i<p->pSrc->nSrc-1); 54764fa4a54fSdrh if( pItem->pSelect ){ 54774fa4a54fSdrh sqlite3TreeViewSelect(pView, pItem->pSelect, 0); 5478485f0039Sdrh } 54794fa4a54fSdrh sqlite3TreeViewPop(pView); 54804fa4a54fSdrh } 54814fa4a54fSdrh sqlite3TreeViewPop(pView); 5482485f0039Sdrh } 5483485f0039Sdrh if( p->pWhere ){ 5484*b08cd3f3Sdrh sqlite3TreeViewItem(pView, "WHERE", (n--)>0); 54854fa4a54fSdrh sqlite3TreeViewExpr(pView, p->pWhere, 0); 54864fa4a54fSdrh sqlite3TreeViewPop(pView); 5487485f0039Sdrh } 5488485f0039Sdrh if( p->pGroupBy ){ 5489*b08cd3f3Sdrh sqlite3TreeViewExprList(pView, p->pGroupBy, (n--)>0, "GROUPBY"); 5490485f0039Sdrh } 5491485f0039Sdrh if( p->pHaving ){ 5492*b08cd3f3Sdrh sqlite3TreeViewItem(pView, "HAVING", (n--)>0); 54934fa4a54fSdrh sqlite3TreeViewExpr(pView, p->pHaving, 0); 54944fa4a54fSdrh sqlite3TreeViewPop(pView); 5495485f0039Sdrh } 5496485f0039Sdrh if( p->pOrderBy ){ 5497*b08cd3f3Sdrh sqlite3TreeViewExprList(pView, p->pOrderBy, (n--)>0, "ORDERBY"); 5498485f0039Sdrh } 5499a84203a0Sdrh if( p->pLimit ){ 5500*b08cd3f3Sdrh sqlite3TreeViewItem(pView, "LIMIT", (n--)>0); 55014fa4a54fSdrh sqlite3TreeViewExpr(pView, p->pLimit, 0); 55024fa4a54fSdrh sqlite3TreeViewPop(pView); 5503a84203a0Sdrh } 5504a84203a0Sdrh if( p->pOffset ){ 5505*b08cd3f3Sdrh sqlite3TreeViewItem(pView, "OFFSET", (n--)>0); 55064fa4a54fSdrh sqlite3TreeViewExpr(pView, p->pOffset, 0); 55074fa4a54fSdrh sqlite3TreeViewPop(pView); 5508485f0039Sdrh } 55094fa4a54fSdrh if( p->pPrior ){ 55104fa4a54fSdrh const char *zOp = "UNION"; 55114fa4a54fSdrh switch( p->op ){ 55124fa4a54fSdrh case TK_ALL: zOp = "UNION ALL"; break; 55134fa4a54fSdrh case TK_INTERSECT: zOp = "INTERSECT"; break; 55144fa4a54fSdrh case TK_EXCEPT: zOp = "EXCEPT"; break; 5515485f0039Sdrh } 5516*b08cd3f3Sdrh sqlite3TreeViewItem(pView, zOp, (n--)>0); 5517*b08cd3f3Sdrh sqlite3TreeViewSelect(pView, p->pPrior, 0); 55184fa4a54fSdrh sqlite3TreeViewPop(pView); 5519a84203a0Sdrh } 55204fa4a54fSdrh sqlite3TreeViewPop(pView); 5521a84203a0Sdrh } 55224fa4a54fSdrh #endif /* SQLITE_DEBUG */ 5523