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

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

?? expr.c

?? 新版輕量級嵌入式數據庫
?? 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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人开心网精品视频| 99精品视频在线播放观看| 国产精品素人一区二区| 欧美日韩午夜精品| 国产成人福利片| 日本不卡视频在线| 亚洲自拍偷拍欧美| 中文字幕中文字幕在线一区 | 欧美一级欧美三级| 91视频www| 国产成人午夜精品5599| 成人99免费视频| 美女视频免费一区| 无码av中文一区二区三区桃花岛| 一色屋精品亚洲香蕉网站| 久久综合色之久久综合| 91精品国产入口在线| 91国在线观看| 色综合久久99| 99精品在线免费| www.亚洲免费av| 国产精品一级二级三级| 精品一区二区免费看| 日韩精品欧美精品| 午夜精品一区二区三区免费视频| 亚洲精品视频观看| 亚洲人成在线播放网站岛国 | 日韩一区二区三区精品视频| 在线视频中文字幕一区二区| 96av麻豆蜜桃一区二区| 99久久久久久| av色综合久久天堂av综合| 成人av午夜电影| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 午夜精品久久久久久久久久 | 国产精品乱码一区二区三区软件| 2023国产一二三区日本精品2022| 日韩欧美一级精品久久| 欧美v日韩v国产v| 久久亚洲精华国产精华液 | 成人高清免费在线播放| 国产91清纯白嫩初高中在线观看| 国产一区二区三区电影在线观看 | 亚洲伦理在线精品| 亚洲黄色免费网站| 亚洲高清视频中文字幕| 日日摸夜夜添夜夜添亚洲女人| 天堂精品中文字幕在线| 日本午夜一区二区| 久久精品久久综合| 国产乱码字幕精品高清av | 国产精品白丝av| 成人免费不卡视频| 在线观看一区二区视频| 欧美日韩精品欧美日韩精品 | 久久99国产精品久久99| 欧美日韩亚洲综合| 国产精品色哟哟| 欧美日本在线观看| 日韩免费成人网| 久久久久久久精| 国产精品福利一区| 最新日韩av在线| 亚洲免费三区一区二区| 精品区一区二区| 亚洲免费看黄网站| 精品福利二区三区| 亚洲一区二区精品3399| 中文字幕亚洲精品在线观看| 欧美激情一区二区三区全黄| 欧美videossexotv100| ●精品国产综合乱码久久久久| 94-欧美-setu| 欧美伦理影视网| 日本视频中文字幕一区二区三区| 亚洲手机成人高清视频| 日韩在线播放一区二区| 国产成人在线视频播放| 91国产丝袜在线播放| 欧美一区二区三区四区视频| 国产精品网站在线| 午夜精品一区二区三区电影天堂| 国产一区二区三区在线观看免费 | 色狠狠综合天天综合综合| 欧美日韩国产a| 国产拍欧美日韩视频二区| 综合分类小说区另类春色亚洲小说欧美| 亚洲天堂免费在线观看视频| 青青草97国产精品免费观看| 国产一区二区精品在线观看| 欧美日韩视频在线观看一区二区三区 | 欧美一级黄色大片| 国产欧美一区二区三区网站| 亚洲一区二区不卡免费| 国产成人精品亚洲日本在线桃色 | 久久看人人爽人人| 亚洲午夜在线视频| 懂色av一区二区在线播放| 欧美精品黑人性xxxx| 中文字幕一区二区三区在线不卡| 久久er精品视频| 欧美日韩精品欧美日韩精品| 中文字幕一区二区三区乱码在线| 日本亚洲三级在线| 在线中文字幕一区| 国产精品精品国产色婷婷| 黄页网站大全一区二区| 欧美精品第1页| 亚洲国产日韩a在线播放| 成人综合日日夜夜| 精品国产亚洲在线| 婷婷开心激情综合| 色悠悠久久综合| 国产精品久久久久桃色tv| 国内精品久久久久影院薰衣草| 91精品蜜臀在线一区尤物| 亚洲综合一二三区| 91国偷自产一区二区使用方法| 中文子幕无线码一区tr| 国产精品资源网站| 久久免费偷拍视频| 国产又黄又大久久| 精品国产91乱码一区二区三区| 91成人免费在线| 国产成人综合自拍| 日韩一区二区三区在线视频| 亚洲风情在线资源站| 91蜜桃免费观看视频| 亚洲欧美在线aaa| 国产91富婆露脸刺激对白| 欧美v日韩v国产v| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品成人一区二区三区四区| 成人h动漫精品一区二| 夜夜爽夜夜爽精品视频| 欧美大片免费久久精品三p| 最新不卡av在线| 欧美国产欧美综合| 综合精品久久久| 中文字幕国产一区| 亚洲欧美综合另类在线卡通| 国产喷白浆一区二区三区| 国产精品天美传媒沈樵| 亚洲精品一区在线观看| 亚洲精品一区二区三区福利| 欧美一级片在线| 欧美精品一区二区三区在线 | 日韩电影一区二区三区| 日韩免费性生活视频播放| 国产91精品久久久久久久网曝门| 亚洲免费伊人电影| 精品国产乱子伦一区| 97aⅴ精品视频一二三区| 久久电影网站中文字幕| 亚洲三级电影网站| 26uuu色噜噜精品一区二区| 在线一区二区三区做爰视频网站| 久久99精品国产.久久久久 | 91麻豆6部合集magnet| 蜜臀av在线播放一区二区三区| 1000精品久久久久久久久| 91精品国产一区二区| 色综合久久88色综合天天6| 黄网站免费久久| 日日摸夜夜添夜夜添亚洲女人| 国产精品情趣视频| 精品久久一区二区| 欧美网站大全在线观看| caoporen国产精品视频| 久久99精品久久久久久久久久久久| 亚洲乱码中文字幕| 久久久久久久久一| 日韩色在线观看| 欧美色综合久久| 99免费精品在线| 岛国av在线一区| 国产原创一区二区| 蜜臀久久久久久久| 亚洲一二三专区| 亚洲欧美二区三区| 国产精品久久久久影院老司| 久久免费午夜影院| 欧美电影免费观看高清完整版在 | 国产91丝袜在线播放| 美女高潮久久久| 亚洲国产成人av| 亚洲激情六月丁香| 亚洲欧洲日韩av| 国产精品三级久久久久三级| 久久久久久一二三区| 婷婷国产在线综合| 成人v精品蜜桃久久一区| 亚洲综合图片区| 欧美日本国产视频| 日本不卡免费在线视频| 在线免费视频一区二区| 中文字幕一区二区三区在线观看| 九九九精品视频| 精品国产免费人成电影在线观看四季 | 精品剧情v国产在线观看在线|