⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pragma.c

📁 sqlite数据库管理系统开放源码
💻 C
📖 第 1 页 / 共 2 页
字号:
    }  }else#endif  if( flagPragma(pParse, zLeft, zRight) ){    /* The flagPragma() call also generates any necessary code */  }else  if( sqliteStrICmp(zLeft, "table_info")==0 ){    Table *pTab;    pTab = sqliteFindTable(db, zRight, 0);    if( pTab ){      static VdbeOpList tableInfoPreface[] = {        { OP_ColumnName,  0, 0,       "cid"},        { OP_ColumnName,  1, 0,       "name"},        { OP_ColumnName,  2, 0,       "type"},        { OP_ColumnName,  3, 0,       "notnull"},        { OP_ColumnName,  4, 0,       "dflt_value"},        { OP_ColumnName,  5, 1,       "pk"},      };      int i;      sqliteVdbeAddOpList(v, ArraySize(tableInfoPreface), tableInfoPreface);      sqliteViewGetColumnNames(pParse, pTab);      for(i=0; i<pTab->nCol; i++){        sqliteVdbeAddOp(v, OP_Integer, i, 0);        sqliteVdbeOp3(v, OP_String, 0, 0, pTab->aCol[i].zName, 0);        sqliteVdbeOp3(v, OP_String, 0, 0,           pTab->aCol[i].zType ? pTab->aCol[i].zType : "numeric", 0);        sqliteVdbeAddOp(v, OP_Integer, pTab->aCol[i].notNull, 0);        sqliteVdbeOp3(v, OP_String, 0, 0,           pTab->aCol[i].zDflt, P3_STATIC);        sqliteVdbeAddOp(v, OP_Integer, pTab->aCol[i].isPrimKey, 0);        sqliteVdbeAddOp(v, OP_Callback, 6, 0);      }    }  }else  if( sqliteStrICmp(zLeft, "index_info")==0 ){    Index *pIdx;    Table *pTab;    pIdx = sqliteFindIndex(db, zRight, 0);    if( pIdx ){      static VdbeOpList tableInfoPreface[] = {        { OP_ColumnName,  0, 0,       "seqno"},        { OP_ColumnName,  1, 0,       "cid"},        { OP_ColumnName,  2, 1,       "name"},      };      int i;      pTab = pIdx->pTable;      sqliteVdbeAddOpList(v, ArraySize(tableInfoPreface), tableInfoPreface);      for(i=0; i<pIdx->nColumn; i++){        int cnum = pIdx->aiColumn[i];        sqliteVdbeAddOp(v, OP_Integer, i, 0);        sqliteVdbeAddOp(v, OP_Integer, cnum, 0);        assert( pTab->nCol>cnum );        sqliteVdbeOp3(v, OP_String, 0, 0, pTab->aCol[cnum].zName, 0);        sqliteVdbeAddOp(v, OP_Callback, 3, 0);      }    }  }else  if( sqliteStrICmp(zLeft, "index_list")==0 ){    Index *pIdx;    Table *pTab;    pTab = sqliteFindTable(db, zRight, 0);    if( pTab ){      v = sqliteGetVdbe(pParse);      pIdx = pTab->pIndex;    }    if( pTab && pIdx ){      int i = 0;       static VdbeOpList indexListPreface[] = {        { OP_ColumnName,  0, 0,       "seq"},        { OP_ColumnName,  1, 0,       "name"},        { OP_ColumnName,  2, 1,       "unique"},      };      sqliteVdbeAddOpList(v, ArraySize(indexListPreface), indexListPreface);      while(pIdx){        sqliteVdbeAddOp(v, OP_Integer, i, 0);        sqliteVdbeOp3(v, OP_String, 0, 0, pIdx->zName, 0);        sqliteVdbeAddOp(v, OP_Integer, pIdx->onError!=OE_None, 0);        sqliteVdbeAddOp(v, OP_Callback, 3, 0);        ++i;        pIdx = pIdx->pNext;      }    }  }else  if( sqliteStrICmp(zLeft, "foreign_key_list")==0 ){    FKey *pFK;    Table *pTab;    pTab = sqliteFindTable(db, zRight, 0);    if( pTab ){      v = sqliteGetVdbe(pParse);      pFK = pTab->pFKey;    }    if( pTab && pFK ){      int i = 0;       static VdbeOpList indexListPreface[] = {        { OP_ColumnName,  0, 0,       "id"},        { OP_ColumnName,  1, 0,       "seq"},        { OP_ColumnName,  2, 0,       "table"},        { OP_ColumnName,  3, 0,       "from"},        { OP_ColumnName,  4, 1,       "to"},      };      sqliteVdbeAddOpList(v, ArraySize(indexListPreface), indexListPreface);      while(pFK){        int j;        for(j=0; j<pFK->nCol; j++){          sqliteVdbeAddOp(v, OP_Integer, i, 0);          sqliteVdbeAddOp(v, OP_Integer, j, 0);          sqliteVdbeOp3(v, OP_String, 0, 0, pFK->zTo, 0);          sqliteVdbeOp3(v, OP_String, 0, 0,                           pTab->aCol[pFK->aCol[j].iFrom].zName, 0);          sqliteVdbeOp3(v, OP_String, 0, 0, pFK->aCol[j].zCol, 0);          sqliteVdbeAddOp(v, OP_Callback, 5, 0);        }        ++i;        pFK = pFK->pNextFrom;      }    }  }else  if( sqliteStrICmp(zLeft, "database_list")==0 ){    int i;    static VdbeOpList indexListPreface[] = {      { OP_ColumnName,  0, 0,       "seq"},      { OP_ColumnName,  1, 0,       "name"},      { OP_ColumnName,  2, 1,       "file"},    };    sqliteVdbeAddOpList(v, ArraySize(indexListPreface), indexListPreface);    for(i=0; i<db->nDb; i++){      if( db->aDb[i].pBt==0 ) continue;      assert( db->aDb[i].zName!=0 );      sqliteVdbeAddOp(v, OP_Integer, i, 0);      sqliteVdbeOp3(v, OP_String, 0, 0, db->aDb[i].zName, 0);      sqliteVdbeOp3(v, OP_String, 0, 0,           sqliteBtreeGetFilename(db->aDb[i].pBt), 0);      sqliteVdbeAddOp(v, OP_Callback, 3, 0);    }  }else  /*  **   PRAGMA temp_store  **   PRAGMA temp_store = "default"|"memory"|"file"  **  ** Return or set the local value of the temp_store flag.  Changing  ** the local value does not make changes to the disk file and the default  ** value will be restored the next time the database is opened.  **  ** Note that it is possible for the library compile-time options to  ** override this setting  */  if( sqliteStrICmp(zLeft, "temp_store")==0 ){    static VdbeOpList getTmpDbLoc[] = {      { OP_ColumnName,  0, 1,        "temp_store"},      { OP_Callback,    1, 0,        0},    };    if( pRight->z==pLeft->z ){      sqliteVdbeAddOp(v, OP_Integer, db->temp_store, 0);      sqliteVdbeAddOpList(v, ArraySize(getTmpDbLoc), getTmpDbLoc);    }else{      changeTempStorage(pParse, zRight);    }  }else  /*  **   PRAGMA default_temp_store  **   PRAGMA default_temp_store = "default"|"memory"|"file"  **  ** Return or set the value of the persistent temp_store flag.  Any  ** change does not take effect until the next time the database is  ** opened.  **  ** Note that it is possible for the library compile-time options to  ** override this setting  */  if( sqliteStrICmp(zLeft, "default_temp_store")==0 ){    static VdbeOpList getTmpDbLoc[] = {      { OP_ColumnName,  0, 1,        "temp_store"},      { OP_ReadCookie,  0, 5,        0},      { OP_Callback,    1, 0,        0}};    if( pRight->z==pLeft->z ){      sqliteVdbeAddOpList(v, ArraySize(getTmpDbLoc), getTmpDbLoc);    }else{      sqliteBeginWriteOperation(pParse, 0, 0);      sqliteVdbeAddOp(v, OP_Integer, getTempStore(zRight), 0);      sqliteVdbeAddOp(v, OP_SetCookie, 0, 5);      sqliteEndWriteOperation(pParse);    }  }else#ifndef NDEBUG  if( sqliteStrICmp(zLeft, "parser_trace")==0 ){    extern void sqliteParserTrace(FILE*, char *);    if( getBoolean(zRight) ){      sqliteParserTrace(stdout, "parser: ");    }else{      sqliteParserTrace(0, 0);    }  }else#endif  if( sqliteStrICmp(zLeft, "integrity_check")==0 ){    int i, j, addr;    /* Code that initializes the integrity check program.  Set the    ** error count 0    */    static VdbeOpList initCode[] = {      { OP_Integer,     0, 0,        0},      { OP_MemStore,    0, 1,        0},      { OP_ColumnName,  0, 1,        "integrity_check"},    };    /* Code to do an BTree integrity check on a single database file.    */    static VdbeOpList checkDb[] = {      { OP_SetInsert,   0, 0,        "2"},      { OP_Integer,     0, 0,        0},    /* 1 */      { OP_OpenRead,    0, 2,        0},      { OP_Rewind,      0, 7,        0},    /* 3 */      { OP_Column,      0, 3,        0},    /* 4 */      { OP_SetInsert,   0, 0,        0},      { OP_Next,        0, 4,        0},    /* 6 */      { OP_IntegrityCk, 0, 0,        0},    /* 7 */      { OP_Dup,         0, 1,        0},      { OP_String,      0, 0,        "ok"},      { OP_StrEq,       0, 12,       0},    /* 10 */      { OP_MemIncr,     0, 0,        0},      { OP_String,      0, 0,        "*** in database "},      { OP_String,      0, 0,        0},    /* 13 */      { OP_String,      0, 0,        " ***\n"},      { OP_Pull,        3, 0,        0},      { OP_Concat,      4, 1,        0},      { OP_Callback,    1, 0,        0},    };    /* Code that appears at the end of the integrity check.  If no error    ** messages have been generated, output OK.  Otherwise output the    ** error message    */    static VdbeOpList endCode[] = {      { OP_MemLoad,     0, 0,        0},      { OP_Integer,     0, 0,        0},      { OP_Ne,          0, 0,        0},    /* 2 */      { OP_String,      0, 0,        "ok"},      { OP_Callback,    1, 0,        0},    };    /* Initialize the VDBE program */    sqliteVdbeAddOpList(v, ArraySize(initCode), initCode);    /* Do an integrity check on each database file */    for(i=0; i<db->nDb; i++){      HashElem *x;      /* Do an integrity check of the B-Tree      */      addr = sqliteVdbeAddOpList(v, ArraySize(checkDb), checkDb);      sqliteVdbeChangeP1(v, addr+1, i);      sqliteVdbeChangeP2(v, addr+3, addr+7);      sqliteVdbeChangeP2(v, addr+6, addr+4);      sqliteVdbeChangeP2(v, addr+7, i);      sqliteVdbeChangeP2(v, addr+10, addr+ArraySize(checkDb));      sqliteVdbeChangeP3(v, addr+13, db->aDb[i].zName, P3_STATIC);      /* Make sure all the indices are constructed correctly.      */      sqliteCodeVerifySchema(pParse, i);      for(x=sqliteHashFirst(&db->aDb[i].tblHash); x; x=sqliteHashNext(x)){        Table *pTab = sqliteHashData(x);        Index *pIdx;        int loopTop;        if( pTab->pIndex==0 ) continue;        sqliteVdbeAddOp(v, OP_Integer, i, 0);        sqliteVdbeOp3(v, OP_OpenRead, 1, pTab->tnum, pTab->zName, 0);        for(j=0, pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext, j++){          if( pIdx->tnum==0 ) continue;          sqliteVdbeAddOp(v, OP_Integer, pIdx->iDb, 0);          sqliteVdbeOp3(v, OP_OpenRead, j+2, pIdx->tnum, pIdx->zName, 0);        }        sqliteVdbeAddOp(v, OP_Integer, 0, 0);        sqliteVdbeAddOp(v, OP_MemStore, 1, 1);        loopTop = sqliteVdbeAddOp(v, OP_Rewind, 1, 0);        sqliteVdbeAddOp(v, OP_MemIncr, 1, 0);        for(j=0, pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext, j++){          int k, jmp2;          static VdbeOpList idxErr[] = {            { OP_MemIncr,     0,  0,  0},            { OP_String,      0,  0,  "rowid "},            { OP_Recno,       1,  0,  0},            { OP_String,      0,  0,  " missing from index "},            { OP_String,      0,  0,  0},    /* 4 */            { OP_Concat,      4,  0,  0},            { OP_Callback,    1,  0,  0},          };          sqliteVdbeAddOp(v, OP_Recno, 1, 0);          for(k=0; k<pIdx->nColumn; k++){            int idx = pIdx->aiColumn[k];            if( idx==pTab->iPKey ){              sqliteVdbeAddOp(v, OP_Recno, 1, 0);            }else{              sqliteVdbeAddOp(v, OP_Column, 1, idx);            }          }          sqliteVdbeAddOp(v, OP_MakeIdxKey, pIdx->nColumn, 0);          if( db->file_format>=4 ) sqliteAddIdxKeyType(v, pIdx);          jmp2 = sqliteVdbeAddOp(v, OP_Found, j+2, 0);          addr = sqliteVdbeAddOpList(v, ArraySize(idxErr), idxErr);          sqliteVdbeChangeP3(v, addr+4, pIdx->zName, P3_STATIC);          sqliteVdbeChangeP2(v, jmp2, sqliteVdbeCurrentAddr(v));        }        sqliteVdbeAddOp(v, OP_Next, 1, loopTop+1);        sqliteVdbeChangeP2(v, loopTop, sqliteVdbeCurrentAddr(v));        for(j=0, pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext, j++){          static VdbeOpList cntIdx[] = {             { OP_Integer,      0,  0,  0},             { OP_MemStore,     2,  1,  0},             { OP_Rewind,       0,  0,  0},  /* 2 */             { OP_MemIncr,      2,  0,  0},             { OP_Next,         0,  0,  0},  /* 4 */             { OP_MemLoad,      1,  0,  0},             { OP_MemLoad,      2,  0,  0},             { OP_Eq,           0,  0,  0},  /* 7 */             { OP_MemIncr,      0,  0,  0},             { OP_String,       0,  0,  "wrong # of entries in index "},             { OP_String,       0,  0,  0},  /* 10 */             { OP_Concat,       2,  0,  0},             { OP_Callback,     1,  0,  0},          };          if( pIdx->tnum==0 ) continue;          addr = sqliteVdbeAddOpList(v, ArraySize(cntIdx), cntIdx);          sqliteVdbeChangeP1(v, addr+2, j+2);          sqliteVdbeChangeP2(v, addr+2, addr+5);          sqliteVdbeChangeP1(v, addr+4, j+2);          sqliteVdbeChangeP2(v, addr+4, addr+3);          sqliteVdbeChangeP2(v, addr+7, addr+ArraySize(cntIdx));          sqliteVdbeChangeP3(v, addr+10, pIdx->zName, P3_STATIC);        }      }     }    addr = sqliteVdbeAddOpList(v, ArraySize(endCode), endCode);    sqliteVdbeChangeP2(v, addr+2, addr+ArraySize(endCode));  }else  {}  sqliteFree(zLeft);  sqliteFree(zRight);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -