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

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

?? 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.257 2006/03/17 13:56:34 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){  int op = pExpr->op;  if( op==TK_AS ){    return sqlite3ExprAffinity(pExpr->pLeft);  }  if( op==TK_SELECT ){    return sqlite3ExprAffinity(pExpr->pSelect->pEList->a[0].pExpr);  }#ifndef SQLITE_OMIT_CAST  if( op==TK_CAST ){    return sqlite3AffinityType(&pExpr->token);  }#endif  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 || pExpr->op==TK_CAST) && !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    ** affinity, use that. Otherwise use no affinity.    */    if( sqlite3IsNumericAffinity(aff1) || sqlite3IsNumericAffinity(aff2) ){      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_NONE;  }else{    /* One side is a column, the other is not. Use the columns affinity. */    assert( aff1==0 || aff2==0 );    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);  switch( aff ){    case SQLITE_AFF_NONE:      return 1;    case SQLITE_AFF_TEXT:      return idx_affinity==SQLITE_AFF_TEXT;    default:      return sqlite3IsNumericAffinity(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" means the top of the stack.** "#1" means the next down on the stack.  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( pParse->nested==0 ){    sqlite3ErrorMsg(pParse, "near \"%T\": syntax error", pToken);    return 0;  }  if( v==0 ) return 0;  p = sqlite3Expr(TK_REGISTER, 0, 0, pToken);  if( p==0 ){    return 0;  /* Malloc failed */  }  depth = atoi((char*)&pToken->z[1]);  p->iTable = pParse->nMem++;  sqlite3VdbeAddOp(v, OP_Dup, depth, 0);  sqlite3VdbeAddOp(v, OP_MemStore, p->iTable, 1);  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( !sqlite3MallocFailed() && 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;  assert( pToken );  pNew = sqliteMalloc( sizeof(Expr) );  if( pNew==0 ){    sqlite3ExprListDelete(pList); /* Avoid leaking memory when malloc fails */    return 0;  }  pNew->op = TK_FUNCTION;  pNew->pList = pList;  assert( pToken->dyn==0 );  pNew->token = *pToken;  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((char*)&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;        sqliteReallocOrFree((void**)&pParse->apVarExpr,                       pParse->nVarExprAlloc*sizeof(pParse->apVarExpr[0]) );      }      if( !sqlite3MallocFailed() ){        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 Expr.token field might be a string literal that is quoted.** If so, remove the quotation marks.*/void sqlite3DequoteExpr(Expr *p){  if( ExprHasAnyProperty(p, EP_Dequoted) ){    return;  }  ExprSetProperty(p, EP_Dequoted);  if( p->token.dyn==0 ){    sqlite3TokenCopy(&p->token, &p->token);  }  sqlite3Dequote((char*)p->token.z);}/*** 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;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线播放亚洲一区| 欧美性大战久久久久久久| 国产精品无码永久免费888| 91看片淫黄大片一级在线观看| 亚洲国产美女搞黄色| 精品国产污污免费网站入口 | 国产精品成人免费在线| 在线国产电影不卡| 国产麻豆精品在线观看| 日韩激情一二三区| 最新热久久免费视频| 精品欧美一区二区久久| 色天使色偷偷av一区二区| 精品亚洲免费视频| 天堂久久一区二区三区| 国产精品传媒入口麻豆| 久久免费电影网| 欧美成人aa大片| 欧美剧情片在线观看| 一本色道综合亚洲| 成人在线一区二区三区| 国产在线精品一区二区三区不卡 | 欧美日韩黄视频| 99久久久国产精品| 国产精品一区久久久久| 日本伊人午夜精品| 首页综合国产亚洲丝袜| 一区二区三区 在线观看视频| 中文字幕不卡在线播放| www国产成人| 精品国一区二区三区| 欧美一区二区三区在线电影| 欧美视频一区二区| 在线欧美日韩精品| 欧美亚洲愉拍一区二区| 欧美性色综合网| 91传媒视频在线播放| 色综合久久天天综合网| 91麻豆免费视频| 色吊一区二区三区| 在线一区二区视频| 在线中文字幕一区二区| 欧美视频完全免费看| 欧美日韩一区三区| 欧美久久久久免费| 欧美一区二区三区视频在线观看 | 国产成人午夜视频| 国产精品18久久久久久久网站| 国产麻豆91精品| 丁香婷婷综合色啪| 成人蜜臀av电影| 91成人在线精品| 欧美日韩第一区日日骚| 欧美精三区欧美精三区| 欧美一区二区三区男人的天堂| 日韩色在线观看| 欧美r级在线观看| 国产欧美一区二区在线| 国产精品私房写真福利视频| 亚洲欧洲一区二区在线播放| 亚洲精品国产无天堂网2021 | 高清不卡一区二区| 国产91在线观看丝袜| 成人国产亚洲欧美成人综合网| av在线综合网| 欧美卡1卡2卡| 国产婷婷精品av在线| 亚洲青青青在线视频| 日日骚欧美日韩| 国产91富婆露脸刺激对白| 成人av动漫网站| 91成人看片片| 日韩三级中文字幕| 日韩一区欧美小说| 亚洲第四色夜色| 黄色日韩网站视频| 色999日韩国产欧美一区二区| 欧美久久久久久久久中文字幕| 久久久久久久一区| 亚洲主播在线播放| 国产精品亚洲午夜一区二区三区 | 99精品欧美一区二区三区综合在线| 色拍拍在线精品视频8848| 欧美日本一区二区三区四区| 2020国产精品| 亚洲最新视频在线播放| 另类人妖一区二区av| 豆国产96在线|亚洲| 欧美精品自拍偷拍| 国产精品久久久99| 日韩精品乱码av一区二区| 国产大陆精品国产| 91精品国产一区二区三区香蕉| 国产精品女人毛片| 日本不卡123| 色综合久久精品| 久久久精品免费网站| 性做久久久久久免费观看欧美| 国产suv精品一区二区6| 日韩一区国产二区欧美三区| 最新久久zyz资源站| 狠狠久久亚洲欧美| 678五月天丁香亚洲综合网| 中文在线资源观看网站视频免费不卡 | 国产91丝袜在线播放| 69堂成人精品免费视频| 中文字幕一区二区三区不卡| 久久99精品久久久久久动态图| 色中色一区二区| 国产欧美一区视频| 精品一区二区免费在线观看| 欧美三电影在线| 自拍av一区二区三区| 激情五月婷婷综合网| 欧美日本视频在线| 一区二区三区四区国产精品| 国产成a人亚洲| 久久综合成人精品亚洲另类欧美| 日韩综合小视频| 91福利资源站| 亚洲精品成a人| 99综合影院在线| 国产精品视频一二三区| 国产资源在线一区| 日韩欧美中文字幕公布| 天天免费综合色| 欧美色综合天天久久综合精品| 亚洲天堂中文字幕| 成人高清在线视频| 国产欧美日韩精品在线| 国产一区二区三区日韩| 日韩亚洲欧美中文三级| 视频一区视频二区中文字幕| 欧美日韩一区二区三区在线| 亚洲三级电影全部在线观看高清| 成人一区二区三区中文字幕| 国产欧美精品一区aⅴ影院| 国产一区免费电影| 国产日产精品一区| 国产a精品视频| 自拍偷在线精品自拍偷无码专区| 菠萝蜜视频在线观看一区| 欧美激情在线观看视频免费| 国产a级毛片一区| 最新日韩在线视频| 91成人看片片| 日韩av网站免费在线| 日韩免费一区二区| 国产精品一区二区在线观看不卡| 久久久久久久久久久久久夜| 国产激情视频一区二区三区欧美| 中文无字幕一区二区三区| 成人免费精品视频| 国产精品成人一区二区艾草| 日本高清成人免费播放| 亚洲一区二区欧美日韩| 91精品国产综合久久久蜜臀粉嫩 | 99国产欧美另类久久久精品 | 中文字幕一区二区三区在线播放| 成人精品免费视频| 最好看的中文字幕久久| 色一情一伦一子一伦一区| 一个色在线综合| 日韩免费在线观看| 国产馆精品极品| 亚洲同性gay激情无套| 欧美性猛片aaaaaaa做受| 日韩av在线免费观看不卡| 欧美mv日韩mv| 99re成人精品视频| 亚洲成人午夜电影| 911精品产国品一二三产区| 麻豆国产精品视频| 欧美国产禁国产网站cc| 91黄色免费观看| 精品写真视频在线观看| 久久久亚洲午夜电影| 91精品办公室少妇高潮对白| 三级久久三级久久久| 欧美国产亚洲另类动漫| 99国内精品久久| 一区二区成人在线视频| 日韩精品专区在线影院重磅| 日韩av中文字幕一区二区三区| 亚洲国产精品成人久久综合一区| 欧美亚洲综合网| 国产成人精品影院| 午夜影院久久久| 亚洲国产成人午夜在线一区| 欧美在线制服丝袜| 国产一区二区调教| 亚洲永久精品国产| 国产日韩欧美电影| 欧美精品少妇一区二区三区| 高清久久久久久| 麻豆视频观看网址久久| 洋洋av久久久久久久一区| 久久丝袜美腿综合| 欧美日韩精品一区二区| 成人污污视频在线观看|