亚洲欧美第一页_禁久久精品乱码_粉嫩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.230 2005/09/23 21:11:54 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 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. */    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);  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" 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(&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( !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;        sqlite3ReallocOrFree((void**)&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 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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费一区二区三区视频 | 亚洲欧洲性图库| 一区二区成人在线| 1024成人网| 寂寞少妇一区二区三区| 在线观看区一区二| 国产精品夫妻自拍| 国产福利91精品一区| 91麻豆精品国产自产在线观看一区 | 欧美精品久久天天躁| 国产精品久久久久久久蜜臀| 奇米一区二区三区av| 欧美网站一区二区| 成人免费在线观看入口| 亚洲午夜激情av| 不卡的电影网站| 国产拍欧美日韩视频二区| 国产精品欧美极品| 综合激情成人伊人| 国产成人av影院| 久久久久国产精品厨房| 亚洲国产日日夜夜| 国产综合久久久久久久久久久久 | av不卡在线播放| 国产偷国产偷亚洲高清人白洁 | 4438x成人网最大色成网站| ●精品国产综合乱码久久久久| 一区二区三区免费网站| 不卡av在线网| 国产精品视频一二| 99久久精品国产导航| 国产精品美女久久久久av爽李琼 | 久久激情综合网| 91精品国产91综合久久蜜臀| 亚洲国产精品久久艾草纯爱| 在线亚洲高清视频| 亚洲图片欧美色图| 欧美精品乱人伦久久久久久| 日韩成人免费电影| 久久综合视频网| 国产成人福利片| 国产精品久久久久久久久动漫| 亚欧色一区w666天堂| 欧美日韩一区小说| 麻豆精品在线播放| 久久亚洲综合av| 成人精品电影在线观看| 亚洲天堂成人网| 欧美日韩免费一区二区三区视频| 久久久99精品久久| 成人免费看片app下载| 亚洲美女在线一区| 51精品秘密在线观看| 国产一区在线观看视频| 1024成人网| 91精品一区二区三区久久久久久| 亚洲欧美区自拍先锋| 欧美嫩在线观看| 日本成人在线视频网站| 国产欧美日韩激情| 国内精品久久久久影院薰衣草| 在线观看免费视频综合| 美女国产一区二区三区| 国产精品嫩草久久久久| 精品视频在线免费看| 国产福利不卡视频| 亚洲专区一二三| 久久久噜噜噜久久中文字幕色伊伊| 日日欢夜夜爽一区| 欧美性大战xxxxx久久久| 久久精品av麻豆的观看方式| 国产精品久久久久久一区二区三区| 国产精品一区免费视频| 亚洲与欧洲av电影| 欧美精品一区二区久久久| 色系网站成人免费| 国产精品一二三四五| 亚洲www啪成人一区二区麻豆| 欧美丝袜第三区| 国产精品一级二级三级| 日本少妇一区二区| 亚洲欧美日本在线| 欧美日韩二区三区| 成人黄色片在线观看| 麻豆专区一区二区三区四区五区| 3atv在线一区二区三区| 91毛片在线观看| 国产在线观看一区二区| 天天影视网天天综合色在线播放| 色婷婷av一区二区三区软件| 亚洲免费在线看| 欧美午夜视频网站| 亚洲va中文字幕| 日韩色在线观看| 国产精品伊人色| 麻豆精品一二三| 日韩精品一区第一页| 国产精品久久午夜| 国产偷国产偷精品高清尤物| 日韩精品一区二区三区视频在线观看| 久久精品99久久久| 亚洲一二三四久久| 自拍av一区二区三区| 中文字幕精品三区| 久久免费电影网| 91网址在线看| eeuss鲁一区二区三区| 国产电影精品久久禁18| 国产真实乱对白精彩久久| 中文字幕av资源一区| 久久婷婷久久一区二区三区| 日韩视频123| 日韩精品一区二区三区四区 | 久久99精品一区二区三区三区| 久久久美女毛片| 色国产精品一区在线观看| 99国产麻豆精品| 91麻豆国产在线观看| 一本色道久久综合亚洲91| 色就色 综合激情| 日本高清不卡视频| 欧美日韩一区二区在线视频| 另类小说一区二区三区| 久久69国产一区二区蜜臀| 国产中文一区二区三区| 成人亚洲一区二区一| www.亚洲精品| 欧美色电影在线| 91精品啪在线观看国产60岁| 日韩欧美一区在线| 在线观看一区二区视频| 欧美视频一区在线| 日韩欧美一区在线| 91国偷自产一区二区使用方法| 精品中文字幕一区二区| 国产成人av电影在线观看| 成人免费毛片aaaaa**| 色婷婷久久综合| 91精品欧美一区二区三区综合在| 99国内精品久久| 欧美日本乱大交xxxxx| 国产91高潮流白浆在线麻豆| 91免费观看国产| 日韩午夜激情电影| 国产精品美女久久久久av爽李琼| 日韩一区二区在线看片| 欧美日本在线观看| 久久伊99综合婷婷久久伊| 91超碰这里只有精品国产| 2021中文字幕一区亚洲| 综合激情成人伊人| 久久精品99久久久| 91社区在线播放| 日韩精品一区二| 亚洲三级久久久| 国产一区二区在线观看免费| 91女人视频在线观看| 精品噜噜噜噜久久久久久久久试看 | 国产+成+人+亚洲欧洲自线| 色婷婷综合视频在线观看| www久久精品| 午夜在线成人av| 99久久免费视频.com| 精品久久久久久综合日本欧美| 日韩欧美国产综合| 日韩一区二区三区精品视频| 国产精品久久久久久户外露出| 国产精品美女久久久久久2018| 国产精品乱码久久久久久| 日韩av网站在线观看| 色综合久久久网| 中文字幕巨乱亚洲| 国产中文字幕精品| 欧美一级二级在线观看| 一区二区三区成人| 丰满少妇在线播放bd日韩电影| 成人av资源在线观看| 精品美女被调教视频大全网站| 久久久久久一二三区| 午夜精品久久久久久久久| 日韩国产在线观看| 欧美丝袜丝交足nylons图片| 中文字幕亚洲成人| 懂色av中文字幕一区二区三区| 99精品视频中文字幕| 久久久久久影视| 国内一区二区在线| 日韩欧美国产综合一区| 日本特黄久久久高潮| 欧美久久久久久久久| 亚洲 欧美综合在线网络| 欧美在线一二三四区| 亚洲制服欧美中文字幕中文字幕| 日本不卡一区二区三区高清视频| 国产精品18久久久久久久久| 日韩精品一区二区三区视频在线观看 | 亚洲欧美日韩国产成人精品影院| 午夜久久电影网| 欧美日韩精品久久久| 亚洲成人综合视频|