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

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

?? intepretor.cpp

?? 實現一個精簡型單用戶SQL引擎(DBMS)MiniSQL
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
    {
     case I:
        tmin.IntValue = atoi(StrNow->str);
        NextStr();
        PassCommon("and");
        tmax.IntValue = atoi(StrNow->str);
        NextStr();
        pColtemp->SetColValint(optype,tmin.IntValue,tmax.IntValue);
       break;
     
     case F:
        tmin.FloatValue = atof(StrNow->str);
        NextStr();
        PassCommon("and");
        tmax.FloatValue = atof(StrNow->str);
        NextStr();
        pColtemp->SetColValfloat(optype,tmin.FloatValue,tmax.FloatValue);
       break;

     case C:
        tmin.pCharValue = FilterQuota(StrNow->str);
        NextStr();
        PassCommon("and");
        tmax.pCharValue = FilterQuota(StrNow->str);
        pColtemp->SetColValstr(optype,tmin.pCharValue,tmax.pCharValue);
       break;
    }
   }
else                                                  //<--- 非Between的操作類型,就可以直接設置
  {SetMin_Max(tmin,tmax,optype,coltype);
  pColtemp->SetColVal(optype,tmin,tmax);
  }                                                   //<--- 善后工作
PassCommon(")");
if(CompStrEver(StrNow->str,","))
  NextStr();
else
  if(CompStrEver(StrNow->str,")"))
    *NotEnd = 0;
}


EOPE_TYPE Ch_csVstrBlk::GetOptype()
{
/***************************************************************** 
** 功能描述:得到一個列的操作類型
 enum Operator_Type {B, BE, L, LE, E, NE,BETWEEN};
****************************************************************/ 
VSTR_BLK_PTR StrTemp = StrNow;
EOPE_TYPE ret;
if(CompStrEver(StrNow->str,"between"))
  ret = BETWEEN;
else
  if(CompStrEver(StrNow->str,"="))
	 {
	  NextStr();
	  ret = E;}
    else
      if(CompStrEver(StrNow->str,"!"))
       {NextStr();
        PassCommon("=");
        ret = NE;
       }
        else
          if(CompStrEver(StrNow->str,">"))
           {NextStr();
              if(CompStrEver(StrNow->str,"="))
			  {NextStr();
			  ret = BE;}
              else 
                ret = B;
            }
          else
            if(CompStrEver(StrNow->str,"<"))
             {NextStr();
              if(CompStrEver(StrNow->str,"="))                  //<--- 但是<時還要判斷后面有沒有=
			  {
				 NextStr();
			     ret = LE;}
              else 
                ret = L;
              }
            else
              ThrowStrErr(GET_OP_ERR,iNumNowInVstr);
    return ret;

}

pCreate_Column Ch_csVstrBlk::GetColForCheck(char* str,pCreate_Column pHead)
{
/***************************************************************** 
** 已知check中的列名,在前面已經只好的pHead列表中尋找該列的各個相關信息
****************************************************************/ 
pCreate_Column pCol = pHead,pTemp;
bool bNotFind = 1;
for(;pCol != 0 && bNotFind; pCol = pCol->next)
  {bNotFind = !(CompStrEver(pCol->ColumnName,str));
	pTemp = pCol;
  }                                         //<--- 在列鏈表中搜索所要找的列名
NextStr();
if(bNotFind)
  ThrowStrErr(COLNAMEERR_IN_CHECK,iNumNowInVstr);//<--- check的列名實際上并不存在
return pTemp;
}

pCreate_Column Ch_csVstrBlk::GetColumnInfo(bool* NotEnd,bool& bPriKeyExist)
{
  char strColName[NAMEMAXLEN];
  bool bError = 0,isnulltemp = 0,ispritemp = 0,ColNotEnd = 1;
  VSTR_BLK_PTR StrTemp = 0;
  pCreate_Column csOneCol = 0;
  ECOL_TYPE coltypetemp;
  int iStrlen = 0;
  strcpy(strColName,StrNow->str);           //<--- 得到一列的列名信息
  NextStr();
  if(CompStrEver(StrNow->str,"char"))
    {                                       //<--- 針對字段類型是char
	 coltypetemp = C;
	 NextStr();
     PassCommon("(");
	 if(CompStrEver(StrNow->str,")"))
		iStrlen = 0;
     else
	 {iStrlen = atoi(StrNow->str);
	 NextStr();}                            //<--- 如將har(8)中的8取得
     PassCommon(")");
    }
  else
    if(CompStrEver(StrNow->str,"int"))
     {                                      //<--- 針對字段類型是int
      coltypetemp = I;
	  NextStr();
     }
    else
      if(CompStrEver(StrNow->str,"float"))
        {                                   //<--- 針對字段類型是float
         coltypetemp = F;
		 NextStr();
        }
      else
       bError = 1;
  if(bError == 1)
    ThrowStrErr(COLUMNTYPE,iNumNowInVstr);

  do
  {
   if(CompStrEver(StrNow->str,"notnull"))   //<--- 有關一個列的定義之后如帶有notnull或primary則記錄下信息
    {isnulltemp = 0;
      NextStr();}
   else
     if(CompStrEver(StrNow->str,"primary"))
    {ispritemp = 1;
     bPriKeyExist = 1;                      //<--- primary key exists
      NextStr();}
     else
       if(CompStrEver(StrNow->str,","))
    {
     ColNotEnd = 0;
     NextStr();
    }
       else
         if(CompStrEver(StrNow->str,")"))
          {ColNotEnd = 0;
           *NotEnd = 0;}
           else 
             ThrowStrErr(KEYWORD,iNumNowInVstr);
  }while(ColNotEnd);
  csOneCol = new Create_Column(strColName,coltypetemp,iStrlen,isnulltemp,ispritemp);

  return csOneCol;
}


void Ch_csVstrBlk::NextStr()
{ 
/***************************************************************** 
** 功能描述:    轉到下一個StrNow(即StrNow = StrNow->Next)
****************************************************************/ 
  iNumNowInVstr++;
  StrNow = StrNow->next;
}


char* Ch_csVstrBlk::GetTBName()
{                                           //<--- 取得表名
  char* strTBName = new char[NAMEMAXLEN];
  strcpy(strTBName,StrNow->str);
  NextStr();
  return strTBName;
}


void Ch_csVstrBlk::PassCommon(char* pStrIn)
 /***************************************************************** 
對StrNow當前所指的字串是否和輸入的字串一致,一致---
則iNumNowInVstr++,StrNow = StrNow->next;
不一致--- ThrowStrErr(COMMON,iNumNowInVstr);
COMMON--意為所處理的是一般的關鍵字解析
****************************************************************/ 
{
  if(CompStrEver(pStrIn,StrNow->str))
    NextStr();
  else
    ThrowStrErr(COMMON,iNumNowInVstr);
}

ECMD_TYPE Ch_csVstrBlk::ResolveCmd()
 /***************************************************************** 
** 功能描述:解析取得命令
//<---  enum MSG { CREATE, SELECT, INSERT, UPDATE, DELETE, DROP, QUIT} ;
****************************************************************/ 
{
  ECMD_TYPE ReturnValue = HELP;
  bool bError = 0;
if(CompStrEver(StrNow->str,"HELP"))
	{ReturnValue = HELP;}
else
    if(CompStrEver(StrNow->str,"QUIT"))
	    {ReturnValue = QUIT;}
    else
        if(CompStrEver(StrNow->str,"EXIT"))
	        {ReturnValue = QUIT;}
        else
            if(CompStrEver(StrNow->str,"DROPDB"))
                ReturnValue = DROPDB;
            else
                if(CompStrEver(StrNow->str,"SHOWDB"))
                	ReturnValue = SHOWDB;
                else
                    if(CompStrEver(StrNow->str,"USE"))
                        ReturnValue = USE;
                    else
                        if(CompStrEver(StrNow->str,"NEW"))
                            ReturnValue = NEW;
                         else
                            if(CompStrEver(StrNow->str,"DROP"))
                                ReturnValue = DROP;
                            else
                                {
                                if(CompStrEver(StrNow->str,"CREATE"))
                                    ReturnValue = CREATE;
                                  else
                                    if(CompStrEver(StrNow->str,"SELECT"))
                                      ReturnValue = SELECT;
                                    else
                                      if(CompStrEver(StrNow->str,"INSERT"))
                                        ReturnValue = INSERT;
                                      else
                                        if(CompStrEver(StrNow->str,"UPDATE"))
                                          ReturnValue = UPDATE;
                                        else
                                          if(CompStrEver(StrNow->str,"DELETE"))
                                            ReturnValue = DELETE;
                                          else
                                                if(CompStrEver(StrNow->str,"SHOWTABLE"))
                                                  ReturnValue = SHOWTABLE;
                                                else
                                                    bError = 1;}
 
   if(bError == 1)
    ThrowStrErr(RESOLVE,iNumNowInVstr);
  else
    NextStr();                              //<--- 第一個有意字串不出錯,則iNumNowInVstr+1
  return ReturnValue;
}

 void Ch_csVstrBlk::ThrowStrErr(int type,int iNum)
{                                           //<--- 負責構造一個錯誤類并將它拋出來,由主函數來處理
  ErrInfo eiTemp;
  int iLine = 0;
  int i = 0;
  char* str = new char[NAMEMAXLEN];
  VSTR_BLK_PTR StrTemp = StrHead;
  for(;iNum > iLineNum[iLine][1];iLine++)
	  ;
   i = iNum;                               //<--- 查找出錯在那一行
  for(; i != 0;i--)
	  StrTemp = StrTemp->next;             //<--- 查找出錯在哪個有意字串
  eiTemp.iErrType = type;
  eiTemp.iLineNo = iLine;
  strcpy(str,StrTemp->str);
  eiTemp.pErrStr = str;
  throw(eiTemp);
}

//<--- 設置好列中的Min&Max約束
void Ch_csVstrBlk::SetMin_Max(COLVAL temp,COLVAL& min,COLVAL& max,EOPE_TYPE optype,ECOL_TYPE coltype)
 {
	 switch(optype)
  {
  case E:
  case NE:
    switch(coltype)
    {case I:
        min = temp;
        max = min;
        break;
      case F:
		min = temp;
        max = min;
        break;
      case C:
        min = temp;
        max = min;
		break;
    }

  case LE:
  case L:
    switch(coltype)
    {case I:
        max = temp;
        break;
      case F:
        max = temp;
        
        break;
      case C:
        max.pCharValue = FilterQuota(temp.pCharValue);
        
        break;
    } 

  case B:
  case BE:
    switch(coltype)
    {case I:
        min = temp;
        
        break;
      case F:
        min = temp;
        
        break;
      case C:
        min.pCharValue = FilterQuota(temp.pCharValue);
        
        break;
        }
    
  }
 }

 void Ch_csVstrBlk::SetMin_Max(COLVAL& min,COLVAL& max,EOPE_TYPE optype,ECOL_TYPE coltype,bool next)
{
/******************************************************************* 
  功能描述:根據optype給min和max賦值
  當前StrNow必須處在處理的有意字串上
  enum Operator_Type {B, BE, L, LE, E, NE,BETWEEN};
****************************************************************/ 
switch(optype)
  {
  case E:
  case NE:
    switch(coltype)
    {case I:
        min.IntValue = atoi(StrNow->str);
        max.IntValue = min.IntValue;
        break;
      case F:
        min.FloatValue = atof(StrNow->str);
        max.FloatValue = min.FloatValue;
        break;
      case C:
        min.pCharValue = FilterQuota(StrNow->str);
        max.pCharValue = min.pCharValue;
        break;
    }

  case LE:
  case L:
    switch(coltype)
    {case I:
        max.IntValue = atoi(StrNow->str);
        break;
      case F:
        max.FloatValue = atof(StrNow->str);
        
        break;
      case C:
        max.pCharValue = FilterQuota(StrNow->str);
        
        break;
    }
    
  case B:
  case BE:
    switch(coltype)
    {case I:
        min.IntValue = atoi(StrNow->str);
        
        break;
      case F:
        min.FloatValue = atof(StrNow->str);
        
        break;
      case C:
        min.pCharValue = FilterQuota(StrNow->str);
        
        break;
        }
    
  }
	if(next)
		NextStr();

}
 /***********************結構體TB_Create_Info***********************/
 TB_Create_Info::TB_Create_Info(int i,pCreate_Column p,char* str):TotalColumn(i),head(p)
 {
    strcpy(TableName,str);
 }

 /***********************結構體Create_Column***********************/
Create_Column::Create_Column(char* str,ECOL_TYPE coltype,int strlen,bool is_null,bool ispri):
    ColType(coltype),length(strlen),IsNull(is_null),isprimary(ispri),next(0)
{
  strcpy(ColumnName,str);
  switch(coltype)
  {case C ://<--- 即該列為字符
    min.pCharValue = new char[2];
    strcpy(min.pCharValue,"z");
    max.pCharValue = new char[2];
    strcpy(max.pCharValue,"a");
   break;
   case F ://<--- 即該列為浮點數
    min.FloatValue = 1.0;
    max.FloatValue = 0;
   break;
   case I ://<--- 即該列為整數
     min.IntValue = 1;
     max.IntValue = -1;
   break;
   default :
   break;
  }
}

void Create_Column::SetColVal(EOPE_TYPE optype,COLVAL &tMin ,COLVAL &tMax)
{
  OperType = optype;
  min = tMin;
  max = tMax;
}

void Create_Column::SetColValstr(EOPE_TYPE optype,char* chMin = 0,char* chMax = 0)
{
/***************************************************************** 
將Create_Column()里未根據實際初始的min.pCharValue,max.pCharValue初始一下,并設定好長度
****************************************************************/ 
  int iStrLen = length;
  OperType = optype;
  if(chMin != 0)                            //<--- 如果min.pCharValue和max.pCharValue有范圍限制
  {delete min.pCharValue;
  delete max.pCharValue;
  if(length == 0)
	  iStrLen = NAMEMAXLEN;
  min.pCharValue = new char[iStrLen];
  max.pCharValue = new char[iStrLen];
  strcpy(min.pCharValue,chMin);
  strcpy(max.pCharValue,chMax);
  }
}
void Create_Column::SetColValint(EOPE_TYPE optype,int iMin,int iMax)
{
/***************************************************************** 
將Create_Column()里未根據實際初始的min.IntValue,max.IntValue初始一下
****************************************************************/ 
  min.IntValue = iMin;
  max.IntValue = iMax;
  OperType = optype;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91女厕偷拍女厕偷拍高清| 亚洲图片另类小说| 一区二区三区蜜桃| 国产精品一区二区在线观看网站| eeuss鲁片一区二区三区| 日韩午夜在线影院| 亚洲欧美日韩综合aⅴ视频| 国产一区高清在线| 91精品国产综合久久国产大片| 国产精品女人毛片| 精品一区二区成人精品| 一本色道久久综合亚洲精品按摩| 久久久青草青青国产亚洲免观| 午夜激情一区二区三区| 91丨九色丨国产丨porny| 久久久亚洲欧洲日产国码αv| 一区二区三区免费观看| 91亚洲大成网污www| 欧美韩国一区二区| 国产一区二区成人久久免费影院| 欧美一级久久久| 亚洲福中文字幕伊人影院| 91丝袜高跟美女视频| 自拍av一区二区三区| 国产精品 欧美精品| 精品国产不卡一区二区三区| 日产国产欧美视频一区精品| 欧美日韩激情一区| 亚洲成人av电影在线| 欧美在线一二三| 亚洲综合色网站| 欧美亚洲一区二区在线观看| 亚洲免费观看高清完整版在线观看熊 | 国产精品嫩草影院com| 国产精品系列在线播放| 欧美国产97人人爽人人喊| 国产91丝袜在线播放0| 中文成人综合网| fc2成人免费人成在线观看播放| 国产欧美久久久精品影院| 国产91丝袜在线18| 国产精品丝袜黑色高跟| 波多野结衣亚洲| 一区二区三区不卡视频| 欧美日韩不卡一区| 免费观看久久久4p| 久久亚区不卡日本| av毛片久久久久**hd| 亚洲图片一区二区| 欧美va日韩va| 粉嫩av一区二区三区在线播放| 国产精品不卡视频| 欧美三级视频在线播放| 免费人成网站在线观看欧美高清| 久久久亚洲精品石原莉奈| www.爱久久.com| 亚洲综合久久av| 欧美mv日韩mv亚洲| 99re视频精品| 视频在线在亚洲| 国产欧美日韩视频在线观看| 在线观看免费亚洲| 精品在线免费视频| 国产精品久久久久久久久免费丝袜| 色播五月激情综合网| 蜜桃视频一区二区| 最新高清无码专区| 欧美r级电影在线观看| 91在线你懂得| 久久av中文字幕片| 亚洲免费三区一区二区| 欧美成人激情免费网| av不卡在线播放| 精品一区二区三区视频在线观看| 国产精品卡一卡二| 精品国产电影一区二区| 欧美日韩在线电影| 成人高清av在线| 奇米色777欧美一区二区| 综合精品久久久| 久久一夜天堂av一区二区三区| 色猫猫国产区一区二在线视频| 黄色小说综合网站| 日韩影视精彩在线| 自拍av一区二区三区| 国产亚洲va综合人人澡精品| 欧美视频在线不卡| 91在线看国产| 国产精品亚洲一区二区三区在线| 性做久久久久久免费观看欧美| 中文字幕视频一区| 久久久www成人免费无遮挡大片 | 精品美女在线观看| 欧美美女一区二区在线观看| 97精品久久久午夜一区二区三区 | 色噜噜狠狠色综合欧洲selulu| 国产乱色国产精品免费视频| 日韩不卡一区二区| 亚洲一二三四区| 亚洲人成在线观看一区二区| 国产亚洲精品久| xfplay精品久久| 日韩一级免费观看| 欧美精品乱码久久久久久 | 精品国产精品一区二区夜夜嗨| 欧美精品三级日韩久久| 欧美日韩国产美| 欧美亚洲尤物久久| 欧美日韩在线观看一区二区| 欧美亚洲国产bt| 在线免费观看成人短视频| 日本精品视频一区二区| 欧美中文字幕不卡| 欧美性三三影院| 欧美视频精品在线观看| 欧美日本在线视频| 7777精品伊人久久久大香线蕉最新版| 在线中文字幕一区二区| 欧美日韩精品专区| 欧美一级生活片| 91精品国产综合久久久蜜臀粉嫩| 欧美高清视频一二三区 | 欧美一区二区久久| 日韩欧美区一区二| 日韩欧美国产午夜精品| 久久伊人中文字幕| 国产精品进线69影院| 日韩理论片网站| 亚洲超碰精品一区二区| 日本中文一区二区三区| 韩国一区二区在线观看| 成人综合在线观看| 在线观看亚洲a| 7777精品伊人久久久大香线蕉完整版| 制服.丝袜.亚洲.中文.综合| 亚洲精品一区二区三区精华液 | 日本中文字幕一区| 国产精品影视在线| 色悠久久久久综合欧美99| 欧美日韩亚洲丝袜制服| 精品国产91洋老外米糕| 国产偷国产偷精品高清尤物| 国产精品美女视频| 午夜影院在线观看欧美| 久久99国产精品免费网站| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 91麻豆国产福利在线观看| 欧美视频一区二| 久久精品视频免费| 亚洲一区免费观看| 韩国精品主播一区二区在线观看 | 欧美三级电影在线观看| 日韩精品在线网站| 亚洲视频在线观看一区| 美日韩一区二区三区| a4yy欧美一区二区三区| 日韩欧美第一区| 亚洲品质自拍视频| 极品美女销魂一区二区三区| 色婷婷综合久久久中文一区二区| 日韩限制级电影在线观看| 樱桃国产成人精品视频| 国产一区二区视频在线| 欧美亚洲国产一区在线观看网站| 久久久久久久一区| 午夜影院久久久| 色婷婷综合久久| 国产欧美日韩另类视频免费观看| 污片在线观看一区二区| 日韩久久久久久| 亚洲精品国产a| 成人午夜激情视频| 日韩欧美国产一二三区| 午夜精品一区二区三区免费视频 | 午夜精品视频在线观看| 99精品国产99久久久久久白柏| 26uuu久久综合| 日本不卡一区二区三区| 色诱视频网站一区| 成人欧美一区二区三区| 国产成人精品免费| 日韩欧美不卡在线观看视频| 亚洲444eee在线观看| 欧美视频完全免费看| 一区二区欧美国产| 色综合久久综合网欧美综合网| 国产精品私人影院| 国产成人三级在线观看| 久久一夜天堂av一区二区三区| 日韩高清在线观看| 欧美日韩一区二区三区四区五区 | 中文字幕亚洲成人| 国产不卡在线播放| 国产日本亚洲高清| 国产精品白丝jk白祙喷水网站| 精品日韩欧美在线| 精品无人码麻豆乱码1区2区| 欧美xxxxx牲另类人与| 日欧美一区二区| 337p亚洲精品色噜噜噜|