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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? update.c

?? sqlite 3.3.8 支持加密的版本
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
** 2001 September 15
**
** 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 C code routines that are called by the parser
** to handle UPDATE statements.
**
** $Id: update.c,v 1.24 2006/10/12 21:34:22 rmsimpson Exp $
*/
#include "sqliteInt.h"

#ifndef SQLITE_OMIT_VIRTUALTABLE
/* Forward declaration */
static void updateVirtualTable(
  Parse *pParse,       /* The parsing context */
  SrcList *pSrc,       /* The virtual table to be modified */
  Table *pTab,         /* The virtual table */
  ExprList *pChanges,  /* The columns to change in the UPDATE statement */
  Expr *pRowidExpr,    /* Expression used to recompute the rowid */
  int *aXRef,          /* Mapping from columns of pTab to entries in pChanges */
  Expr *pWhere         /* WHERE clause of the UPDATE statement */
);
#endif /* SQLITE_OMIT_VIRTUALTABLE */

/*
** The most recently coded instruction was an OP_Column to retrieve the
** i-th column of table pTab. This routine sets the P3 parameter of the 
** OP_Column to the default value, if any.
**
** The default value of a column is specified by a DEFAULT clause in the 
** column definition. This was either supplied by the user when the table
** was created, or added later to the table definition by an ALTER TABLE
** command. If the latter, then the row-records in the table btree on disk
** may not contain a value for the column and the default value, taken
** from the P3 parameter of the OP_Column instruction, is returned instead.
** If the former, then all row-records are guaranteed to include a value
** for the column and the P3 value is not required.
**
** Column definitions created by an ALTER TABLE command may only have 
** literal default values specified: a number, null or a string. (If a more
** complicated default expression value was provided, it is evaluated 
** when the ALTER TABLE is executed and one of the literal values written
** into the sqlite_master table.)
**
** Therefore, the P3 parameter is only required if the default value for
** the column is a literal number, string or null. The sqlite3ValueFromExpr()
** function is capable of transforming these types of expressions into
** sqlite3_value objects.
*/
void sqlite3ColumnDefault(Vdbe *v, Table *pTab, int i){
  if( pTab && !pTab->pSelect ){
    sqlite3_value *pValue;
    u8 enc = ENC(sqlite3VdbeDb(v));
    Column *pCol = &pTab->aCol[i];
    sqlite3ValueFromExpr(pCol->pDflt, enc, pCol->affinity, &pValue);
    if( pValue ){
      sqlite3VdbeChangeP3(v, -1, (const char *)pValue, P3_MEM);
    }else{
      VdbeComment((v, "# %s.%s", pTab->zName, pCol->zName));
    }
  }
}

/*
** Process an UPDATE statement.
**
**   UPDATE OR IGNORE table_wxyz SET a=b, c=d WHERE e<5 AND f NOT NULL;
**          \_______/ \________/     \______/       \________________/
*            onError   pTabList      pChanges             pWhere
*/
void sqlite3Update(
  Parse *pParse,         /* The parser context */
  SrcList *pTabList,     /* The table in which we should change things */
  ExprList *pChanges,    /* Things to be changed */
  Expr *pWhere,          /* The WHERE clause.  May be null */
  int onError            /* How to handle constraint errors */
){
  int i, j;              /* Loop counters */
  Table *pTab;           /* The table to be updated */
  int addr = 0;          /* VDBE instruction address of the start of the loop */
  WhereInfo *pWInfo;     /* Information about the WHERE clause */
  Vdbe *v;               /* The virtual database engine */
  Index *pIdx;           /* For looping over indices */
  int nIdx;              /* Number of indices that need updating */
  int nIdxTotal;         /* Total number of indices */
  int iCur;              /* VDBE Cursor number of pTab */
  sqlite3 *db;           /* The database structure */
  Index **apIdx = 0;     /* An array of indices that need updating too */
  char *aIdxUsed = 0;    /* aIdxUsed[i]==1 if the i-th index is used */
  int *aXRef = 0;        /* aXRef[i] is the index in pChanges->a[] of the
                         ** an expression for the i-th column of the table.
                         ** aXRef[i]==-1 if the i-th column is not changed. */
  int chngRowid;         /* True if the record number is being changed */
  Expr *pRowidExpr = 0;  /* Expression defining the new record number */
  int openAll = 0;       /* True if all indices need to be opened */
  AuthContext sContext;  /* The authorization context */
  NameContext sNC;       /* The name-context to resolve expressions in */
  int iDb;               /* Database containing the table being updated */

#ifndef SQLITE_OMIT_TRIGGER
  int isView;                  /* Trying to update a view */
  int triggers_exist = 0;      /* True if any row triggers exist */
#endif

  int newIdx      = -1;  /* index of trigger "new" temp table       */
  int oldIdx      = -1;  /* index of trigger "old" temp table       */

  sContext.pParse = 0;
  if( pParse->nErr || sqlite3MallocFailed() ){
    goto update_cleanup;
  }
  db = pParse->db;
  assert( pTabList->nSrc==1 );

  /* Locate the table which we want to update. 
  */
  pTab = sqlite3SrcListLookup(pParse, pTabList);
  if( pTab==0 ) goto update_cleanup;
  iDb = sqlite3SchemaToIndex(pParse->db, pTab->pSchema);

  /* Figure out if we have any triggers and if the table being
  ** updated is a view
  */
#ifndef SQLITE_OMIT_TRIGGER
  triggers_exist = sqlite3TriggersExist(pParse, pTab, TK_UPDATE, pChanges);
  isView = pTab->pSelect!=0;
#else
# define triggers_exist 0
# define isView 0
#endif
#ifdef SQLITE_OMIT_VIEW
# undef isView
# define isView 0
#endif

  if( sqlite3IsReadOnly(pParse, pTab, triggers_exist) ){
    goto update_cleanup;
  }
  if( sqlite3ViewGetColumnNames(pParse, pTab) ){
    goto update_cleanup;
  }
  aXRef = sqliteMallocRaw( sizeof(int) * pTab->nCol );
  if( aXRef==0 ) goto update_cleanup;
  for(i=0; i<pTab->nCol; i++) aXRef[i] = -1;

  /* If there are FOR EACH ROW triggers, allocate cursors for the
  ** special OLD and NEW tables
  */
  if( triggers_exist ){
    newIdx = pParse->nTab++;
    oldIdx = pParse->nTab++;
  }

  /* Allocate a cursors for the main database table and for all indices.
  ** The index cursors might not be used, but if they are used they
  ** need to occur right after the database cursor.  So go ahead and
  ** allocate enough space, just in case.
  */
  pTabList->a[0].iCursor = iCur = pParse->nTab++;
  for(pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext){
    pParse->nTab++;
  }

  /* Initialize the name-context */
  memset(&sNC, 0, sizeof(sNC));
  sNC.pParse = pParse;
  sNC.pSrcList = pTabList;

  /* Resolve the column names in all the expressions of the
  ** of the UPDATE statement.  Also find the column index
  ** for each column to be updated in the pChanges array.  For each
  ** column to be updated, make sure we have authorization to change
  ** that column.
  */
  chngRowid = 0;
  for(i=0; i<pChanges->nExpr; i++){
    if( sqlite3ExprResolveNames(&sNC, pChanges->a[i].pExpr) ){
      goto update_cleanup;
    }
    for(j=0; j<pTab->nCol; j++){
      if( sqlite3StrICmp(pTab->aCol[j].zName, pChanges->a[i].zName)==0 ){
        if( j==pTab->iPKey ){
          chngRowid = 1;
          pRowidExpr = pChanges->a[i].pExpr;
        }
        aXRef[j] = i;
        break;
      }
    }
    if( j>=pTab->nCol ){
      if( sqlite3IsRowid(pChanges->a[i].zName) ){
        chngRowid = 1;
        pRowidExpr = pChanges->a[i].pExpr;
      }else{
        sqlite3ErrorMsg(pParse, "no such column: %s", pChanges->a[i].zName);
        goto update_cleanup;
      }
    }
#ifndef SQLITE_OMIT_AUTHORIZATION
    {
      int rc;
      rc = sqlite3AuthCheck(pParse, SQLITE_UPDATE, pTab->zName,
                           pTab->aCol[j].zName, db->aDb[iDb].zName);
      if( rc==SQLITE_DENY ){
        goto update_cleanup;
      }else if( rc==SQLITE_IGNORE ){
        aXRef[j] = -1;
      }
    }
#endif
  }

  /* Allocate memory for the array apIdx[] and fill it with pointers to every
  ** index that needs to be updated.  Indices only need updating if their
  ** key includes one of the columns named in pChanges or if the record
  ** number of the original table entry is changing.
  */
  for(nIdx=nIdxTotal=0, pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext, nIdxTotal++){
    if( chngRowid ){
      i = 0;
    }else {
      for(i=0; i<pIdx->nColumn; i++){
        if( aXRef[pIdx->aiColumn[i]]>=0 ) break;
      }
    }
    if( i<pIdx->nColumn ) nIdx++;
  }
  if( nIdxTotal>0 ){
    apIdx = sqliteMallocRaw( sizeof(Index*) * nIdx + nIdxTotal );
    if( apIdx==0 ) goto update_cleanup;
    aIdxUsed = (char*)&apIdx[nIdx];
  }
  for(nIdx=j=0, pIdx=pTab->pIndex; pIdx; pIdx=pIdx->pNext, j++){
    if( chngRowid ){
      i = 0;
    }else{
      for(i=0; i<pIdx->nColumn; i++){
        if( aXRef[pIdx->aiColumn[i]]>=0 ) break;
      }
    }
    if( i<pIdx->nColumn ){
      apIdx[nIdx++] = pIdx;
      aIdxUsed[j] = 1;
    }else{
      aIdxUsed[j] = 0;
    }
  }

  /* Begin generating code.
  */
  v = sqlite3GetVdbe(pParse);
  if( v==0 ) goto update_cleanup;
  if( pParse->nested==0 ) sqlite3VdbeCountChanges(v);
  sqlite3BeginWriteOperation(pParse, 1, iDb);

#ifndef SQLITE_OMIT_VIRTUALTABLE
  /* Virtual tables must be handled separately */
  if( IsVirtual(pTab) ){
    updateVirtualTable(pParse, pTabList, pTab, pChanges, pRowidExpr, aXRef,
                       pWhere);
    pWhere = 0;
    pTabList = 0;
    goto update_cleanup;
  }
#endif

  /* Resolve the column names in all the expressions in the
  ** WHERE clause.
  */
  if( sqlite3ExprResolveNames(&sNC, pWhere) ){
    goto update_cleanup;
  }

  /* Start the view context
  */
  if( isView ){
    sqlite3AuthContextPush(pParse, &sContext, pTab->zName);
  }

  /* If we are trying to update a view, realize that view into
  ** a ephemeral table.
  */
  if( isView ){
    Select *pView;
    pView = sqlite3SelectDup(pTab->pSelect);
    sqlite3Select(pParse, pView, SRT_EphemTab, iCur, 0, 0, 0, 0);
    sqlite3SelectDelete(pView);
  }

  /* Begin the database scan
  */
  pWInfo = sqlite3WhereBegin(pParse, pTabList, pWhere, 0);
  if( pWInfo==0 ) goto update_cleanup;

  /* Remember the rowid of every item to be updated.
  */
  sqlite3VdbeAddOp(v, IsVirtual(pTab) ? OP_VRowid : OP_Rowid, iCur, 0);
  sqlite3VdbeAddOp(v, OP_FifoWrite, 0, 0);

  /* End the database scan loop.
  */
  sqlite3WhereEnd(pWInfo);

  /* Initialize the count of updated rows
  */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久中文综合久久牛| 在线观看视频一区| 亚洲综合色成人| 337p日本欧洲亚洲大胆精品| 色狠狠色噜噜噜综合网| 国产精品综合二区| 亚洲成人一二三| 亚洲欧洲av一区二区三区久久| 欧美二区乱c少妇| 99久久久国产精品免费蜜臀| 美女一区二区三区在线观看| 亚洲午夜精品网| 亚洲日韩欧美一区二区在线| 久久久久久电影| 日韩一区二区视频| 欧美最猛性xxxxx直播| 成人亚洲精品久久久久软件| 久久成人18免费观看| 亚洲综合视频在线| 成人欧美一区二区三区1314| 久久女同互慰一区二区三区| 欧美一区二区三区色| 91福利在线观看| 97久久精品人人做人人爽50路| 国产一区二区视频在线播放| 久久精品国产成人一区二区三区| 亚洲成av人片一区二区梦乃| 一区二区三区欧美日韩| 综合网在线视频| 国产精品免费观看视频| 久久蜜臀精品av| 国产精品久久看| 中文字幕不卡三区| 国产女人18水真多18精品一级做| 2023国产精品| 2020日本不卡一区二区视频| 日韩欧美在线不卡| 在线成人av影院| 91精品国产一区二区三区蜜臀| 欧美日韩亚洲综合一区二区三区| 欧美视频一区二| 欧美日韩国产综合视频在线观看| 欧美性大战久久久| 欧美日韩一区二区三区在线| 欧美日韩精品是欧美日韩精品| 欧美色偷偷大香| 91.成人天堂一区| 日韩一二三四区| 日韩三级在线免费观看| 欧美精品一区二区三区四区 | 亚洲欧美乱综合| 亚洲欧洲制服丝袜| 一个色在线综合| 亚洲成人av在线电影| 日本亚洲视频在线| 狠狠色丁香婷综合久久| 国产精品一二三四五| 成人污污视频在线观看| 91一区二区三区在线播放| 91在线观看一区二区| 在线观看欧美黄色| 91精品一区二区三区在线观看| 日韩欧美黄色影院| 久久久久久久精| 成人欧美一区二区三区白人| 亚洲大型综合色站| 精品中文av资源站在线观看| 国产成人午夜高潮毛片| 色综合久久久网| 日韩欧美精品三级| 中文字幕欧美激情一区| 亚洲福利视频一区二区| 蜜桃av噜噜一区| 岛国精品在线观看| 欧美日韩免费观看一区二区三区| 日韩三级视频中文字幕| 国产精品嫩草久久久久| 亚洲一区二区在线免费看| 麻豆国产精品777777在线| 狠狠v欧美v日韩v亚洲ⅴ| 99国产精品视频免费观看| 欧美日韩成人在线| 国产欧美日韩综合精品一区二区| 亚洲精品一二三区| 精品一区二区三区蜜桃| 91麻豆蜜桃一区二区三区| 91精品久久久久久久久99蜜臂| 2023国产一二三区日本精品2022| 爽爽淫人综合网网站| 国产成人aaa| 91精品麻豆日日躁夜夜躁| 中文字幕一区二区三区不卡在线| 视频一区视频二区在线观看| 丰满岳乱妇一区二区三区| 欧美精品视频www在线观看| 国产女人18水真多18精品一级做| 久久欧美一区二区| 婷婷久久综合九色国产成人| 成人精品在线视频观看| 欧美一区二区三区电影| 亚洲视频在线一区| 国产一区二区在线观看免费| 欧美日本在线视频| 亚洲欧洲成人自拍| 国产在线乱码一区二区三区| 欧美日韩在线电影| 亚洲欧洲av在线| 国产精品一区免费视频| 91精品国产入口在线| 亚洲精品免费看| www.欧美日韩| 久久久精品人体av艺术| 美女网站色91| 欧美日韩国产bt| 亚洲在线视频免费观看| 91丨九色丨黑人外教| 国产欧美精品在线观看| 麻豆成人久久精品二区三区小说| 在线观看视频91| 亚洲欧美一区二区三区久本道91| 国产一区二区在线观看视频| 精品免费视频一区二区| 男女性色大片免费观看一区二区 | 国产精品麻豆99久久久久久| 久久se这里有精品| 欧美一区二区三区电影| 日韩1区2区日韩1区2区| 欧美日本视频在线| 亚洲国产日韩精品| 欧美三级电影在线观看| 亚洲午夜一区二区| 在线观看av不卡| 亚洲一区二区三区视频在线播放| 一本大道av一区二区在线播放| 1024国产精品| 成人免费视频播放| 婷婷一区二区三区| 欧美日韩一级黄| 日韩电影一区二区三区| 欧美精品在线观看播放| 日本最新不卡在线| 欧美精品在线一区二区| 免费成人美女在线观看| 91精品国产麻豆| 国产尤物一区二区| 久久久精品国产免大香伊| 国产成人精品午夜视频免费| 中文字幕中文字幕在线一区| 91在线视频观看| 亚洲国产成人porn| 91精品国产91综合久久蜜臀| 美女一区二区三区| 国产日韩精品视频一区| 成人激情视频网站| 一区二区三区欧美在线观看| 91麻豆精品国产91久久久更新时间| 另类的小说在线视频另类成人小视频在线| 日韩一区二区三区精品视频| 国产一区 二区| 国产精品久久二区二区| 欧美三级电影在线看| 久久国产精品99久久人人澡| 日本一区二区三区免费乱视频| 99视频一区二区三区| 亚洲午夜电影在线观看| 欧美大片在线观看一区| 国产精品一区二区男女羞羞无遮挡| 国产精品激情偷乱一区二区∴| 欧美色综合网站| 麻豆专区一区二区三区四区五区| 亚洲国产精品成人久久综合一区| 91麻豆高清视频| 视频一区欧美日韩| 欧美激情一区二区| 欧美亚洲图片小说| 韩国女主播一区二区三区| 国产精品国产三级国产a | 久久久国产精华| 日本乱人伦aⅴ精品| 麻豆国产欧美日韩综合精品二区| 国产精品国产三级国产专播品爱网| 欧美视频在线观看一区二区| 国精产品一区一区三区mba视频| 亚洲精品中文字幕在线观看| 欧美成人三级在线| 色婷婷av一区二区三区软件| 久久精品99国产精品日本| 亚洲欧美日韩国产成人精品影院| 欧美一区三区四区| 成人一区二区视频| 免费观看一级欧美片| 亚洲三级小视频| 久久久99久久精品欧美| 欧美日韩久久一区二区| 成人h动漫精品一区二区| 日产欧产美韩系列久久99| 亚洲视频在线观看一区| 亚洲精品一线二线三线无人区| 欧美日韩精品一区二区天天拍小说| 国产成+人+日韩+欧美+亚洲|