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

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

?? expr.c

?? sqlite 嵌入式數據庫的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*** 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 routines used for analyzing expressions and** for generating VDBE code that evaluates expressions in SQLite.**** $Id: expr.c,v 1.206 2005/06/12 21:35:52 drh Exp $*/#include "sqliteInt.h"#include <ctype.h>/*** Return the 'affinity' of the expression pExpr if any.**** If pExpr is a column, a reference to a column via an 'AS' alias,** or a sub-select with a column as the return value, then the ** affinity of that column is returned. Otherwise, 0x00 is returned,** indicating no affinity for the expression.**** i.e. the WHERE clause expresssions in the following statements all** have an affinity:**** CREATE TABLE t1(a);** SELECT * FROM t1 WHERE a;** SELECT a AS b FROM t1 WHERE b;** SELECT * FROM t1 WHERE (select a from t1);*/char sqlite3ExprAffinity(Expr *pExpr){  if( pExpr->op==TK_AS ){    return sqlite3ExprAffinity(pExpr->pLeft);  }  if( pExpr->op==TK_SELECT ){    return sqlite3ExprAffinity(pExpr->pSelect->pEList->a[0].pExpr);  }  return pExpr->affinity;}/*** Return the default collation sequence for the expression pExpr. If** there is no default collation type, return 0.*/CollSeq *sqlite3ExprCollSeq(Parse *pParse, Expr *pExpr){  CollSeq *pColl = 0;  if( pExpr ){    pColl = pExpr->pColl;    if( pExpr->op==TK_AS && !pColl ){      return sqlite3ExprCollSeq(pParse, pExpr->pLeft);    }  }  if( sqlite3CheckCollSeq(pParse, pColl) ){     pColl = 0;  }  return pColl;}/*** pExpr is an operand of a comparison operator.  aff2 is the** type affinity of the other operand.  This routine returns the** type affinity that should be used for the comparison operator.*/char sqlite3CompareAffinity(Expr *pExpr, char aff2){  char aff1 = sqlite3ExprAffinity(pExpr);  if( aff1 && aff2 ){    /* Both sides of the comparison are columns. If one has numeric or    ** integer affinity, use that. Otherwise use no affinity.    */    if( aff1==SQLITE_AFF_INTEGER || aff2==SQLITE_AFF_INTEGER ){      return SQLITE_AFF_INTEGER;    }else if( aff1==SQLITE_AFF_NUMERIC || aff2==SQLITE_AFF_NUMERIC ){      return SQLITE_AFF_NUMERIC;    }else{      return SQLITE_AFF_NONE;    }  }else if( !aff1 && !aff2 ){    /* Neither side of the comparison is a column.  Compare the    ** results directly.    */    /* return SQLITE_AFF_NUMERIC;  // Ticket #805 */    return SQLITE_AFF_NONE;  }else{    /* One side is a column, the other is not. Use the columns affinity. */    return (aff1 + aff2);  }}/*** pExpr is a comparison operator.  Return the type affinity that should** be applied to both operands prior to doing the comparison.*/static char comparisonAffinity(Expr *pExpr){  char aff;  assert( pExpr->op==TK_EQ || pExpr->op==TK_IN || pExpr->op==TK_LT ||          pExpr->op==TK_GT || pExpr->op==TK_GE || pExpr->op==TK_LE ||          pExpr->op==TK_NE );  assert( pExpr->pLeft );  aff = sqlite3ExprAffinity(pExpr->pLeft);  if( pExpr->pRight ){    aff = sqlite3CompareAffinity(pExpr->pRight, aff);  }  else if( pExpr->pSelect ){    aff = sqlite3CompareAffinity(pExpr->pSelect->pEList->a[0].pExpr, aff);  }  else if( !aff ){    aff = SQLITE_AFF_NUMERIC;  }  return aff;}/*** pExpr is a comparison expression, eg. '=', '<', IN(...) etc.** idx_affinity is the affinity of an indexed column. Return true** if the index with affinity idx_affinity may be used to implement** the comparison in pExpr.*/int sqlite3IndexAffinityOk(Expr *pExpr, char idx_affinity){  char aff = comparisonAffinity(pExpr);  return     (aff==SQLITE_AFF_NONE) ||    (aff==SQLITE_AFF_NUMERIC && idx_affinity==SQLITE_AFF_INTEGER) ||    (aff==SQLITE_AFF_INTEGER && idx_affinity==SQLITE_AFF_NUMERIC) ||    (aff==idx_affinity);}/*** Return the P1 value that should be used for a binary comparison** opcode (OP_Eq, OP_Ge etc.) used to compare pExpr1 and pExpr2.** If jumpIfNull is true, then set the low byte of the returned** P1 value to tell the opcode to jump if either expression** evaluates to NULL.*/static int binaryCompareP1(Expr *pExpr1, Expr *pExpr2, int jumpIfNull){  char aff = sqlite3ExprAffinity(pExpr2);  return ((int)sqlite3CompareAffinity(pExpr1, aff))+(jumpIfNull?0x100:0);}/*** Return a pointer to the collation sequence that should be used by** a binary comparison operator comparing pLeft and pRight.**** If the left hand expression has a collating sequence type, then it is** used. Otherwise the collation sequence for the right hand expression** is used, or the default (BINARY) if neither expression has a collating** type.*/static CollSeq* binaryCompareCollSeq(Parse *pParse, Expr *pLeft, Expr *pRight){  CollSeq *pColl = sqlite3ExprCollSeq(pParse, pLeft);  if( !pColl ){    pColl = sqlite3ExprCollSeq(pParse, pRight);  }  return pColl;}/*** Generate code for a comparison operator.*/static int codeCompare(  Parse *pParse,    /* The parsing (and code generating) context */  Expr *pLeft,      /* The left operand */  Expr *pRight,     /* The right operand */  int opcode,       /* The comparison opcode */  int dest,         /* Jump here if true.  */  int jumpIfNull    /* If true, jump if either operand is NULL */){  int p1 = binaryCompareP1(pLeft, pRight, jumpIfNull);  CollSeq *p3 = binaryCompareCollSeq(pParse, pLeft, pRight);  return sqlite3VdbeOp3(pParse->pVdbe, opcode, p1, dest, (void*)p3, P3_COLLSEQ);}/*** Construct a new expression node and return a pointer to it.  Memory** for this node is obtained from sqliteMalloc().  The calling function** is responsible for making sure the node eventually gets freed.*/Expr *sqlite3Expr(int op, Expr *pLeft, Expr *pRight, const Token *pToken){  Expr *pNew;  pNew = sqliteMalloc( sizeof(Expr) );  if( pNew==0 ){    /* When malloc fails, delete pLeft and pRight. Expressions passed to     ** this function must always be allocated with sqlite3Expr() for this     ** reason.     */    sqlite3ExprDelete(pLeft);    sqlite3ExprDelete(pRight);    return 0;  }  pNew->op = op;  pNew->pLeft = pLeft;  pNew->pRight = pRight;  pNew->iAgg = -1;  if( pToken ){    assert( pToken->dyn==0 );    pNew->span = pNew->token = *pToken;  }else if( pLeft && pRight ){    sqlite3ExprSpan(pNew, &pLeft->span, &pRight->span);  }  return pNew;}/*** When doing a nested parse, you can include terms in an expression** that look like this:   #0 #1 #2 ...  These terms refer to elements** on the stack.  "#0" (or just "#") means the top of the stack.** "#1" means the next down on the stack.  And so forth.  #-1 means** memory location 0.  #-2 means memory location 1.  And so forth.**** This routine is called by the parser to deal with on of those terms.** It immediately generates code to store the value in a memory location.** The returns an expression that will code to extract the value from** that memory location as needed.*/Expr *sqlite3RegisterExpr(Parse *pParse, Token *pToken){  Vdbe *v = pParse->pVdbe;  Expr *p;  int depth;  if( v==0 ) return 0;  if( pParse->nested==0 ){    sqlite3ErrorMsg(pParse, "near \"%T\": syntax error", pToken);    return 0;  }  p = sqlite3Expr(TK_REGISTER, 0, 0, pToken);  if( p==0 ){    return 0;  /* Malloc failed */  }  depth = atoi(&pToken->z[1]);  if( depth>=0 ){    p->iTable = pParse->nMem++;    sqlite3VdbeAddOp(v, OP_Dup, depth, 0);    sqlite3VdbeAddOp(v, OP_MemStore, p->iTable, 1);  }else{    p->iTable = -1-depth;  }  return p;}/*** Join two expressions using an AND operator.  If either expression is** NULL, then just return the other expression.*/Expr *sqlite3ExprAnd(Expr *pLeft, Expr *pRight){  if( pLeft==0 ){    return pRight;  }else if( pRight==0 ){    return pLeft;  }else{    return sqlite3Expr(TK_AND, pLeft, pRight, 0);  }}/*** Set the Expr.span field of the given expression to span all** text between the two given tokens.*/void sqlite3ExprSpan(Expr *pExpr, Token *pLeft, Token *pRight){  assert( pRight!=0 );  assert( pLeft!=0 );  if( !sqlite3_malloc_failed && pRight->z && pLeft->z ){    assert( pLeft->dyn==0 || pLeft->z[pLeft->n]==0 );    if( pLeft->dyn==0 && pRight->dyn==0 ){      pExpr->span.z = pLeft->z;      pExpr->span.n = pRight->n + (pRight->z - pLeft->z);    }else{      pExpr->span.z = 0;    }  }}/*** Construct a new expression node for a function with multiple** arguments.*/Expr *sqlite3ExprFunction(ExprList *pList, Token *pToken){  Expr *pNew;  pNew = sqliteMalloc( sizeof(Expr) );  if( pNew==0 ){    sqlite3ExprListDelete(pList); /* Avoid leaking memory when malloc fails */    return 0;  }  pNew->op = TK_FUNCTION;  pNew->pList = pList;  if( pToken ){    assert( pToken->dyn==0 );    pNew->token = *pToken;  }else{    pNew->token.z = 0;  }  pNew->span = pNew->token;  return pNew;}/*** Assign a variable number to an expression that encodes a wildcard** in the original SQL statement.  **** Wildcards consisting of a single "?" are assigned the next sequential** variable number.**** Wildcards of the form "?nnn" are assigned the number "nnn".  We make** sure "nnn" is not too be to avoid a denial of service attack when** the SQL statement comes from an external source.**** Wildcards of the form ":aaa" or "$aaa" are assigned the same number** as the previous instance of the same wildcard.  Or if this is the first** instance of the wildcard, the next sequenial variable number is** assigned.*/void sqlite3ExprAssignVarNumber(Parse *pParse, Expr *pExpr){  Token *pToken;  if( pExpr==0 ) return;  pToken = &pExpr->token;  assert( pToken->n>=1 );  assert( pToken->z!=0 );  assert( pToken->z[0]!=0 );  if( pToken->n==1 ){    /* Wildcard of the form "?".  Assign the next variable number */    pExpr->iTable = ++pParse->nVar;  }else if( pToken->z[0]=='?' ){    /* Wildcard of the form "?nnn".  Convert "nnn" to an integer and    ** use it as the variable number */    int i;    pExpr->iTable = i = atoi(&pToken->z[1]);    if( i<1 || i>SQLITE_MAX_VARIABLE_NUMBER ){      sqlite3ErrorMsg(pParse, "variable number must be between ?1 and ?%d",          SQLITE_MAX_VARIABLE_NUMBER);    }    if( i>pParse->nVar ){      pParse->nVar = i;    }  }else{    /* Wildcards of the form ":aaa" or "$aaa".  Reuse the same variable    ** number as the prior appearance of the same name, or if the name    ** has never appeared before, reuse the same variable number    */    int i, n;    n = pToken->n;    for(i=0; i<pParse->nVarExpr; i++){      Expr *pE;      if( (pE = pParse->apVarExpr[i])!=0          && pE->token.n==n          && memcmp(pE->token.z, pToken->z, n)==0 ){        pExpr->iTable = pE->iTable;        break;      }    }    if( i>=pParse->nVarExpr ){      pExpr->iTable = ++pParse->nVar;      if( pParse->nVarExpr>=pParse->nVarExprAlloc-1 ){        pParse->nVarExprAlloc += pParse->nVarExprAlloc + 10;        pParse->apVarExpr = sqliteRealloc(pParse->apVarExpr,                       pParse->nVarExprAlloc*sizeof(pParse->apVarExpr[0]) );      }      if( !sqlite3_malloc_failed ){        assert( pParse->apVarExpr!=0 );        pParse->apVarExpr[pParse->nVarExpr++] = pExpr;      }    }  } }/*** Recursively delete an expression tree.*/void sqlite3ExprDelete(Expr *p){  if( p==0 ) return;  if( p->span.dyn ) sqliteFree((char*)p->span.z);  if( p->token.dyn ) sqliteFree((char*)p->token.z);  sqlite3ExprDelete(p->pLeft);  sqlite3ExprDelete(p->pRight);  sqlite3ExprListDelete(p->pList);  sqlite3SelectDelete(p->pSelect);  sqliteFree(p);}/*** The following group of routines make deep copies of expressions,** expression lists, ID lists, and select statements.  The copies can** be deleted (by being passed to their respective ...Delete() routines)** without effecting the originals.**** The expression list, ID, and source lists return by sqlite3ExprListDup(),** sqlite3IdListDup(), and sqlite3SrcListDup() can not be further expanded ** by subsequent calls to sqlite*ListAppend() routines.**** Any tables that the SrcList might point to are not duplicated.*/Expr *sqlite3ExprDup(Expr *p){  Expr *pNew;  if( p==0 ) return 0;  pNew = sqliteMallocRaw( sizeof(*p) );  if( pNew==0 ) return 0;  memcpy(pNew, p, sizeof(*pNew));  if( p->token.z!=0 ){    pNew->token.z = sqliteStrNDup(p->token.z, p->token.n);    pNew->token.dyn = 1;  }else{    assert( pNew->token.z==0 );  }  pNew->span.z = 0;  pNew->pLeft = sqlite3ExprDup(p->pLeft);  pNew->pRight = sqlite3ExprDup(p->pRight);  pNew->pList = sqlite3ExprListDup(p->pList);  pNew->pSelect = sqlite3SelectDup(p->pSelect);  pNew->pTab = p->pTab;  return pNew;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品久久嫩草网站秘色| 日韩三级免费观看| 国产亚洲综合在线| 国产一区二区三区四区五区美女| 欧美成人三级在线| 国内成+人亚洲+欧美+综合在线| 精品国产一区二区精华| 经典一区二区三区| 国产精品久久久久影视| 色呦呦国产精品| 日本特黄久久久高潮| 精品国产乱码久久久久久老虎 | 99久久精品国产导航| 亚洲同性同志一二三专区| 欧亚洲嫩模精品一区三区| 日韩成人一区二区三区在线观看| 日韩精品一区二区三区三区免费| 国产精品综合二区| 亚洲免费视频成人| 欧美一区在线视频| 成人午夜免费av| 亚洲国产一区二区三区青草影视| 欧美男生操女生| 韩国精品久久久| 亚洲免费色视频| 欧美大片顶级少妇| 91麻豆免费看片| 男男gaygay亚洲| 中文字幕一区二区三| 欧美精品在线一区二区| 国产精品一级在线| 亚洲午夜免费电影| 亚洲精品一区二区三区99| 91色porny在线视频| 蜜臀久久99精品久久久画质超高清| 久久久国产精品麻豆| 欧美日韩一区三区四区| 国产宾馆实践打屁股91| 日韩中文字幕av电影| 亚洲国产精品成人综合色在线婷婷| 欧美性生活影院| 国产成人午夜精品5599| 亚洲国产乱码最新视频 | 成人av免费网站| 三级精品在线观看| 椎名由奈av一区二区三区| 欧美成人a在线| 欧美日韩亚洲综合| 99精品在线免费| 国产精品12区| 久久电影国产免费久久电影 | 五月天网站亚洲| 国产精品国产自产拍在线| 日韩精品中午字幕| 欧美日韩激情在线| 91亚洲精华国产精华精华液| 国产在线看一区| 蜜桃视频一区二区三区在线观看| 亚洲精品免费在线观看| 国产精品美女一区二区| 久久色.com| 精品国产欧美一区二区| 6080yy午夜一二三区久久| 91福利社在线观看| 色噜噜狠狠成人网p站| 99国产精品一区| 波多野结衣在线一区| 成人午夜激情在线| 国产成人啪免费观看软件| 狠狠色丁香久久婷婷综合_中| 五月婷婷色综合| 婷婷夜色潮精品综合在线| 亚洲电影你懂得| 亚洲一区二区四区蜜桃| 一区二区三区蜜桃网| 亚洲精品视频自拍| 亚洲激情图片一区| 一区二区三区中文字幕| 亚洲欧美一区二区三区久本道91| 亚洲欧美在线高清| 亚洲免费伊人电影| 亚洲一二三四区| 亚洲va在线va天堂| 视频一区在线视频| 不卡一区二区在线| 99久久亚洲一区二区三区青草| 99麻豆久久久国产精品免费| 97se亚洲国产综合自在线不卡| 成人久久久精品乱码一区二区三区| 国产成人av电影在线| 99久久综合狠狠综合久久| 色婷婷一区二区| 欧美日本乱大交xxxxx| 欧美一区二区性放荡片| 精品国产免费久久| 欧美高清一级片在线观看| 亚洲欧美日韩精品久久久久| 亚洲一区在线视频| 秋霞午夜鲁丝一区二区老狼| 久草在线在线精品观看| 国产99久久久国产精品免费看| 不卡视频在线看| 欧美日韩日本视频| 欧美成人a∨高清免费观看| 中文字幕av在线一区二区三区| 亚洲天堂2014| 日韩精品欧美成人高清一区二区| 麻豆精品在线播放| av在线综合网| 制服丝袜亚洲精品中文字幕| 久久一区二区视频| 中文字幕制服丝袜成人av| 亚洲国产美国国产综合一区二区| 美女免费视频一区| 99re成人在线| 日韩精品一区二区三区中文精品| 国产精品传媒入口麻豆| 亚欧色一区w666天堂| 国产盗摄女厕一区二区三区| 一本一道久久a久久精品| 日韩限制级电影在线观看| 国产精品久久久久久久久动漫| 亚洲18女电影在线观看| 国产精品亚洲一区二区三区妖精| 在线影院国内精品| 国产欧美一二三区| 日韩精品一二三区| 92国产精品观看| 精品盗摄一区二区三区| 一区二区三区精品| 国产成人日日夜夜| 欧美一区二区三区日韩视频| 中文字幕一区二区视频| 另类综合日韩欧美亚洲| 欧美综合一区二区三区| 欧美激情在线一区二区三区| 日本亚洲免费观看| 欧美怡红院视频| 国产精品美女久久久久久2018| 日本成人在线视频网站| 欧美制服丝袜第一页| 国产精品乱码一区二区三区软件| 麻豆精品久久精品色综合| 欧美在线你懂得| 亚洲欧洲精品一区二区三区| 国产麻豆91精品| 欧美一区二区三区喷汁尤物| 亚洲国产日韩a在线播放性色| 成人一区二区三区视频在线观看 | 日本韩国一区二区三区视频| 国产网站一区二区| 奇米精品一区二区三区四区| 欧美亚洲禁片免费| 亚洲三级免费观看| 波多野结衣中文字幕一区| 久久久久国产精品免费免费搜索| 免费观看在线综合| 在线播放91灌醉迷j高跟美女| 一区二区高清免费观看影视大全| 成人免费视频国产在线观看| 久久久久久久久久美女| 久久国产精品第一页| 精品久久一区二区| 精东粉嫩av免费一区二区三区| 日韩视频在线观看一区二区| 青青草一区二区三区| 日韩天堂在线观看| 另类的小说在线视频另类成人小视频在线 | 国产欧美一区二区精品性| 久久99精品国产麻豆婷婷| 日韩精品一区二区三区四区视频| 蜜乳av一区二区| 精品噜噜噜噜久久久久久久久试看| 蜜桃视频在线观看一区二区| 精品乱人伦小说| 国产精品小仙女| 国产精品伦一区| 91丨九色丨国产丨porny| 亚洲精品国产无天堂网2021| 在线观看国产一区二区| 亚洲成人第一页| 日韩精品一区二| 风间由美性色一区二区三区| 国产精品第四页| 欧美视频中文一区二区三区在线观看 | 国产中文字幕精品| 国产午夜一区二区三区| av日韩在线网站| 亚洲国产精品一区二区久久| 制服.丝袜.亚洲.中文.综合| 九九在线精品视频| 亚洲国产精品ⅴa在线观看| 成人免费毛片a| 亚洲一区电影777| 欧美一区二区三区喷汁尤物| 国产久卡久卡久卡久卡视频精品| 最新不卡av在线| 欧美美女bb生活片| 国产成人综合亚洲网站| 中文字幕日韩一区|