亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pragma.c

?? 新版輕量級嵌入式數據庫
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*** 2003 April 6**** The author disclaims copyright to this source code.  In place of** a legal notice, here is a blessing:****    May you do good and not evil.**    May you find forgiveness for yourself and forgive others.**    May you share freely, never taking more than you give.***************************************************************************** This file contains code used to implement the PRAGMA command.**** $Id: pragma.c,v 1.120 2006/03/03 21:20:17 drh Exp $*/#include "sqliteInt.h"#include "os.h"#include <ctype.h>/* Ignore this whole file if pragmas are disabled*/#if !defined(SQLITE_OMIT_PRAGMA) && !defined(SQLITE_OMIT_PARSER)#if defined(SQLITE_DEBUG) || defined(SQLITE_TEST)# include "pager.h"# include "btree.h"#endif/*** Interpret the given string as a safety level.  Return 0 for OFF,** 1 for ON or NORMAL and 2 for FULL.  Return 1 for an empty or ** unrecognized string argument.**** Note that the values returned are one less that the values that** should be passed into sqlite3BtreeSetSafetyLevel().  The is done** to support legacy SQL code.  The safety level used to be boolean** and older scripts may have used numbers 0 for OFF and 1 for ON.*/static int getSafetyLevel(const char *z){                             /* 123456789 123456789 */  static const char zText[] = "onoffalseyestruefull";  static const u8 iOffset[] = {0, 1, 2, 4, 9, 12, 16};  static const u8 iLength[] = {2, 2, 3, 5, 3, 4, 4};  static const u8 iValue[] =  {1, 0, 0, 0, 1, 1, 2};  int i, n;  if( isdigit(*z) ){    return atoi(z);  }  n = strlen(z);  for(i=0; i<sizeof(iLength); i++){    if( iLength[i]==n && sqlite3StrNICmp(&zText[iOffset[i]],z,n)==0 ){      return iValue[i];    }  }  return 1;}/*** Interpret the given string as a boolean value.*/static int getBoolean(const char *z){  return getSafetyLevel(z)&1;}#ifndef SQLITE_OMIT_PAGER_PRAGMAS/*** Interpret the given string as a temp db location. Return 1 for file** backed temporary databases, 2 for the Red-Black tree in memory database** and 0 to use the compile-time default.*/static int getTempStore(const char *z){  if( z[0]>='0' && z[0]<='2' ){    return z[0] - '0';  }else if( sqlite3StrICmp(z, "file")==0 ){    return 1;  }else if( sqlite3StrICmp(z, "memory")==0 ){    return 2;  }else{    return 0;  }}#endif /* SQLITE_PAGER_PRAGMAS */#ifndef SQLITE_OMIT_PAGER_PRAGMAS/*** Invalidate temp storage, either when the temp storage is changed** from default, or when 'file' and the temp_store_directory has changed*/static int invalidateTempStorage(Parse *pParse){  sqlite3 *db = pParse->db;  if( db->aDb[1].pBt!=0 ){    if( db->flags & SQLITE_InTrans ){      sqlite3ErrorMsg(pParse, "temporary storage cannot be changed "        "from within a transaction");      return SQLITE_ERROR;    }    sqlite3BtreeClose(db->aDb[1].pBt);    db->aDb[1].pBt = 0;    sqlite3ResetInternalSchema(db, 0);  }  return SQLITE_OK;}#endif /* SQLITE_PAGER_PRAGMAS */#ifndef SQLITE_OMIT_PAGER_PRAGMAS/*** If the TEMP database is open, close it and mark the database schema** as needing reloading.  This must be done when using the TEMP_STORE** or DEFAULT_TEMP_STORE pragmas.*/static int changeTempStorage(Parse *pParse, const char *zStorageType){  int ts = getTempStore(zStorageType);  sqlite3 *db = pParse->db;  if( db->temp_store==ts ) return SQLITE_OK;  if( invalidateTempStorage( pParse ) != SQLITE_OK ){    return SQLITE_ERROR;  }  db->temp_store = ts;  return SQLITE_OK;}#endif /* SQLITE_PAGER_PRAGMAS *//*** Generate code to return a single integer value.*/static void returnSingleInt(Parse *pParse, const char *zLabel, int value){  Vdbe *v = sqlite3GetVdbe(pParse);  sqlite3VdbeAddOp(v, OP_Integer, value, 0);  if( pParse->explain==0 ){    sqlite3VdbeSetNumCols(v, 1);    sqlite3VdbeSetColName(v, 0, COLNAME_NAME, zLabel, P3_STATIC);  }  sqlite3VdbeAddOp(v, OP_Callback, 1, 0);}#ifndef SQLITE_OMIT_FLAG_PRAGMAS/*** Check to see if zRight and zLeft refer to a pragma that queries** or changes one of the flags in db->flags.  Return 1 if so and 0 if not.** Also, implement the pragma.*/static int flagPragma(Parse *pParse, const char *zLeft, const char *zRight){  static const struct sPragmaType {    const char *zName;  /* Name of the pragma */    int mask;           /* Mask for the db->flags value */  } aPragma[] = {    { "vdbe_trace",               SQLITE_VdbeTrace     },    { "sql_trace",                SQLITE_SqlTrace      },    { "vdbe_listing",             SQLITE_VdbeListing   },    { "full_column_names",        SQLITE_FullColNames  },    { "short_column_names",       SQLITE_ShortColNames },    { "count_changes",            SQLITE_CountRows     },    { "empty_result_callbacks",   SQLITE_NullCallback  },    { "legacy_file_format",       SQLITE_LegacyFileFmt },    { "fullfsync",                SQLITE_FullFSync     },#ifndef SQLITE_OMIT_CHECK    { "ignore_check_constraints", SQLITE_IgnoreChecks  },#endif    /* The following is VERY experimental */    { "writable_schema",          SQLITE_WriteSchema   },    { "omit_readlock",            SQLITE_NoReadlock    },    /* TODO: Maybe it shouldn't be possible to change the ReadUncommitted    ** flag if there are any active statements. */    { "read_uncommitted",         SQLITE_ReadUncommitted },  };  int i;  const struct sPragmaType *p;  for(i=0, p=aPragma; i<sizeof(aPragma)/sizeof(aPragma[0]); i++, p++){    if( sqlite3StrICmp(zLeft, p->zName)==0 ){      sqlite3 *db = pParse->db;      Vdbe *v;      v = sqlite3GetVdbe(pParse);      if( v ){        if( zRight==0 ){          returnSingleInt(pParse, p->zName, (db->flags & p->mask)!=0 );        }else{          if( getBoolean(zRight) ){            db->flags |= p->mask;          }else{            db->flags &= ~p->mask;          }        }      }      return 1;    }  }  return 0;}#endif /* SQLITE_OMIT_FLAG_PRAGMAS *//*** Process a pragma statement.  **** Pragmas are of this form:****      PRAGMA [database.]id [= value]**** The identifier might also be a string.  The value is a string, and** identifier, or a number.  If minusFlag is true, then the value is** a number that was preceded by a minus sign.**** If the left side is "database.id" then pId1 is the database name** and pId2 is the id.  If the left side is just "id" then pId1 is the** id and pId2 is any empty string.*/void sqlite3Pragma(  Parse *pParse,   Token *pId1,        /* First part of [database.]id field */  Token *pId2,        /* Second part of [database.]id field, or NULL */  Token *pValue,      /* Token for <value>, or NULL */  int minusFlag       /* True if a '-' sign preceded <value> */){  char *zLeft = 0;       /* Nul-terminated UTF-8 string <id> */  char *zRight = 0;      /* Nul-terminated UTF-8 string <value>, or NULL */  const char *zDb = 0;   /* The database name */  Token *pId;            /* Pointer to <id> token */  int iDb;               /* Database index for <database> */  sqlite3 *db = pParse->db;  Db *pDb;  Vdbe *v = sqlite3GetVdbe(pParse);  if( v==0 ) return;  /* Interpret the [database.] part of the pragma statement. iDb is the  ** index of the database this pragma is being applied to in db.aDb[]. */  iDb = sqlite3TwoPartName(pParse, pId1, pId2, &pId);  if( iDb<0 ) return;  pDb = &db->aDb[iDb];  /* If the temp database has been explicitly named as part of the   ** pragma, make sure it is open.   */  if( iDb==1 && sqlite3OpenTempDatabase(pParse) ){    return;  }  zLeft = sqlite3NameFromToken(pId);  if( !zLeft ) return;  if( minusFlag ){    zRight = sqlite3MPrintf("-%T", pValue);  }else{    zRight = sqlite3NameFromToken(pValue);  }  zDb = ((iDb>0)?pDb->zName:0);  if( sqlite3AuthCheck(pParse, SQLITE_PRAGMA, zLeft, zRight, zDb) ){    goto pragma_out;  } #ifndef SQLITE_OMIT_PAGER_PRAGMAS  /*  **  PRAGMA [database.]default_cache_size  **  PRAGMA [database.]default_cache_size=N  **  ** The first form reports the current persistent setting for the  ** page cache size.  The value returned is the maximum number of  ** pages in the page cache.  The second form sets both the current  ** page cache size value and the persistent page cache size value  ** stored in the database file.  **  ** The default cache size is stored in meta-value 2 of page 1 of the  ** database file.  The cache size is actually the absolute value of  ** this memory location.  The sign of meta-value 2 determines the  ** synchronous setting.  A negative value means synchronous is off  ** and a positive value means synchronous is on.  */  if( sqlite3StrICmp(zLeft,"default_cache_size")==0 ){    static const VdbeOpList getCacheSize[] = {      { OP_ReadCookie,  0, 2,        0},  /* 0 */      { OP_AbsValue,    0, 0,        0},      { OP_Dup,         0, 0,        0},      { OP_Integer,     0, 0,        0},      { OP_Ne,          0, 6,        0},      { OP_Integer,     0, 0,        0},  /* 5 */      { OP_Callback,    1, 0,        0},    };    int addr;    if( sqlite3ReadSchema(pParse) ) goto pragma_out;    if( !zRight ){      sqlite3VdbeSetNumCols(v, 1);      sqlite3VdbeSetColName(v, 0, COLNAME_NAME, "cache_size", P3_STATIC);      addr = sqlite3VdbeAddOpList(v, ArraySize(getCacheSize), getCacheSize);      sqlite3VdbeChangeP1(v, addr, iDb);      sqlite3VdbeChangeP1(v, addr+5, MAX_PAGES);    }else{      int size = atoi(zRight);      if( size<0 ) size = -size;      sqlite3BeginWriteOperation(pParse, 0, iDb);      sqlite3VdbeAddOp(v, OP_Integer, size, 0);      sqlite3VdbeAddOp(v, OP_ReadCookie, iDb, 2);      addr = sqlite3VdbeAddOp(v, OP_Integer, 0, 0);      sqlite3VdbeAddOp(v, OP_Ge, 0, addr+3);      sqlite3VdbeAddOp(v, OP_Negative, 0, 0);      sqlite3VdbeAddOp(v, OP_SetCookie, iDb, 2);      pDb->pSchema->cache_size = size;      sqlite3BtreeSetCacheSize(pDb->pBt, pDb->pSchema->cache_size);    }  }else  /*  **  PRAGMA [database.]page_size  **  PRAGMA [database.]page_size=N  **  ** The first form reports the current setting for the  ** database page size in bytes.  The second form sets the  ** database page size value.  The value can only be set if  ** the database has not yet been created.  */  if( sqlite3StrICmp(zLeft,"page_size")==0 ){    Btree *pBt = pDb->pBt;    if( !zRight ){      int size = pBt ? sqlite3BtreeGetPageSize(pBt) : 0;      returnSingleInt(pParse, "page_size", size);    }else{      sqlite3BtreeSetPageSize(pBt, atoi(zRight), -1);    }  }else#endif /* SQLITE_OMIT_PAGER_PRAGMAS */  /*  **  PRAGMA [database.]auto_vacuum  **  PRAGMA [database.]auto_vacuum=N  **  ** Get or set the (boolean) value of the database 'auto-vacuum' parameter.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
紧缚奴在线一区二区三区| 欧美一区二区三区免费在线看 | 国产精品高潮呻吟| 日本视频一区二区三区| 日韩一区二区高清| 日韩理论片网站| 久久久www免费人成精品| 亚洲另类色综合网站| 97精品电影院| 中文字幕av一区 二区| 亚洲一卡二卡三卡四卡| 国产iv一区二区三区| 欧美综合一区二区| 国产精品三级久久久久三级| 午夜久久福利影院| 91麻豆国产自产在线观看| 青青草国产成人99久久| 国产精品蜜臀av| 欧美无人高清视频在线观看| 中文字幕一区在线观看视频| 国产成人午夜精品影院观看视频| 国产成人精品免费网站| 91精品国产全国免费观看| 亚洲精品国产品国语在线app| 91免费版pro下载短视频| 一区二区三区日韩精品视频| 色欧美日韩亚洲| 日韩福利电影在线观看| 国产三级精品三级| 欧美精品在线视频| 国产精品一区二区x88av| 亚洲欧美激情在线| 欧美一区二区国产| 色视频欧美一区二区三区| 三级一区在线视频先锋| 欧美电影免费提供在线观看| 毛片一区二区三区| 成人免费在线视频观看| 4438x成人网最大色成网站| 天天色图综合网| 久久一区二区三区四区| 99re成人精品视频| 九九热在线视频观看这里只有精品| 男人的j进女人的j一区| 偷拍日韩校园综合在线| 欧美午夜寂寞影院| 国产伦精一区二区三区| 亚洲视频一二区| 国产精品久久免费看| 天堂影院一区二区| 欧美va天堂va视频va在线| 在线观看亚洲一区| 91网站最新网址| 国产麻豆精品视频| 麻豆成人久久精品二区三区小说| 中文字幕一区二区三区精华液| 久久日韩精品一区二区五区| 欧美亚洲愉拍一区二区| jlzzjlzz欧美大全| av电影在线观看完整版一区二区 | 日韩欧美国产综合一区| 精品国产乱码久久久久久久久| 欧美日韩激情一区二区| 91丨九色丨国产丨porny| 蜜臂av日日欢夜夜爽一区| 日日夜夜一区二区| 亚洲自拍偷拍欧美| 日韩黄色免费网站| 一区二区三区高清| 国产精品丝袜在线| 美腿丝袜在线亚洲一区| 国产综合色产在线精品| 日韩av网站免费在线| 欧美日韩国产一二三| 一区二区三区在线视频观看58| 麻豆国产精品官网| 亚洲精品一区二区三区福利| 青青草97国产精品免费观看无弹窗版| 91高清视频在线| 亚洲乱码精品一二三四区日韩在线| 国产激情一区二区三区四区| 久久久综合网站| 成人在线综合网| 中文字幕不卡在线观看| 国产成人在线视频免费播放| 久久久久99精品国产片| 国产激情一区二区三区四区| 日本一区二区三区电影| 丁香婷婷综合五月| 亚洲欧美国产高清| 成人影视亚洲图片在线| 亚洲福利视频三区| 日韩免费一区二区三区在线播放| 理论片日本一区| 久久免费看少妇高潮| 91蝌蚪porny成人天涯| 亚洲尤物在线视频观看| 精品日本一线二线三线不卡| 免费的国产精品| 国产精品美女www爽爽爽| 99精品一区二区| 亚洲成a人v欧美综合天堂| 日韩午夜三级在线| 成人午夜精品一区二区三区| 亚洲人成精品久久久久久| 欧美日韩在线三区| 国产精品99久久久久久久女警 | 国产成人免费视频| 日本不卡一二三| 亚洲国产精品自拍| 欧美国产一区视频在线观看| 日韩精品在线网站| 波多野结衣中文字幕一区| 美女在线观看视频一区二区| 国产精品区一区二区三| 日韩欧美国产系列| 欧美人与性动xxxx| 欧美日韩精品一区二区| 91精品视频网| 51午夜精品国产| 色婷婷一区二区三区四区| 成人一区二区三区| 日本美女一区二区三区视频| 日韩在线观看一区二区| 亚洲成av人影院在线观看网| 有码一区二区三区| 午夜精品福利久久久| 五月婷婷激情综合网| 韩国中文字幕2020精品| 大白屁股一区二区视频| 91久久一区二区| 久久久久97国产精华液好用吗| 国产精品久久久久久久浪潮网站| 综合婷婷亚洲小说| 国产麻豆精品一区二区| 91亚洲精品乱码久久久久久蜜桃| 欧美日韩一区二区三区不卡| 26uuu色噜噜精品一区| 亚洲欧洲日产国产综合网| 激情成人综合网| 色激情天天射综合网| 色国产综合视频| 日韩丝袜情趣美女图片| 夜夜精品视频一区二区| 成人午夜伦理影院| 欧美日韩一二三| 中文字幕一区二区不卡| 精品一区二区三区免费| 欧美性猛交一区二区三区精品| 国产亚洲一二三区| 久久精品国产99久久6| 欧美三级三级三级爽爽爽| 欧美另类久久久品| 一区二区三区精密机械公司| 国产精品一区二区视频| 91精品国产91久久久久久一区二区 | 亚洲第一福利一区| 欧美日韩精品一区二区三区四区| 中文成人综合网| 成人少妇影院yyyy| 亚洲欧美乱综合| 日本电影欧美片| 丝袜国产日韩另类美女| 69久久99精品久久久久婷婷| 日本在线不卡一区| 日韩视频在线你懂得| 日韩伦理电影网| 国产成人精品免费| 国产精品乱人伦中文| 99久久精品免费观看| 亚洲精品中文字幕乱码三区| 欧美中文字幕一二三区视频| 亚洲www啪成人一区二区麻豆 | 奇米一区二区三区| 在线播放日韩导航| 99久久精品国产导航| 亚洲成人动漫在线免费观看| 精品久久久久久久久久久久久久久久久 | 亚洲超碰精品一区二区| 精品国产乱码久久久久久图片| 韩国欧美国产1区| 亚洲精品国产精品乱码不99| 日韩欧美一级二级| 欧美三级在线看| 97aⅴ精品视频一二三区| 婷婷夜色潮精品综合在线| 国产欧美一区二区精品仙草咪| 99久精品国产| 国产精品77777| 天堂一区二区在线免费观看| 欧美国产一区在线| 欧美国产日韩在线观看| 欧美二区三区91| 欧美三级电影在线看| 99久久免费视频.com| 久久精品国产精品亚洲精品| 日日摸夜夜添夜夜添精品视频| 亚洲免费av高清| 亚洲福中文字幕伊人影院| 亚洲丝袜另类动漫二区|