亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

自己動手做一個SQL解釋器

2019-11-18 20:21:34
字體:
來源:轉載
供稿:網友
自己動手做一個SQL解釋器
在一些小型的應用中,完全沒有必要使用大型數據庫軟件。自己做一個SQL解釋器就能用數據庫的方式來管理了。
這個解釋器,能解釋常用的SQL命令。你可以自行添加其他功能。

<?php
class DB_text {
  var $conn;
  var $classname = "db_text";
  var $database;
  function on_create() {
  }
  function connect($database_name) {
    $this->database = $database_name;
    if(! file_exists($database_name)) {
      $this->conn = array();
      $this->_close();
    }
    $fp = fopen($this->database,"r");
    $this->conn = unserialize(fread($fp,filesize($this->database)));
    fclose($fp);
  }
  function &query($query) {
    if(eregi("select ",$query)) return $this->_select($query);
    if(eregi("insert ",$query)) return $this->_insert($query);
    if(eregi("delete ",$query)) return $this->_delete($query);
    if(eregi("update ",$query)) return $this->_update($query);
    return array();
  }
  function fetch_row(&$result) {
    if(list($key,$value) = each($result))
      return $value;
    return false;
  }
  function num_rows($result) {
    return count($result);
  }

  /**
   * query的輔助函數
   */
  function _select($query) {
    if(eregi("(order by (.+))",$query,$regs)) {
      $order = $regs[2];
      $query = eregi_replace($regs[1],"",$query);
    }
    if(eregi("(group by (.+))",$query,$regs)) {
      $group = $regs[2];
      $query = eregi_replace($regs[1],"",$query);
    }
    eregi("select .* from ([0-9a-z_]+) *(where +(.+))?",$query,$regs);
    if($regs[3] != "") {
      $keys = $this->_where($regs[3],"/$this->conn[$regs[1]]");
      while(list($key,$value) = each($keys)) {
        $rs[] = $this->conn[$regs[1]][$value];
      }
    }else {
      $rs = $this->conn[$regs[1]];
    }
    if($order) {
      sscanf($order,"%s %s",$key,$type);
      if(empty($type)) $type = "asc";
        $this->_sort($rs,$key,$type);
    }
    return $rs;
  }
  function _insert($query) {
    eregi("insert +into +([0-9a-z_]+) *(.+) *values? *(.+)",$query,$regs);
    eval("/$key=array$regs[2];");
    eval("/$value=array$regs[3];");
    for($i=0;$i<count($key);$i++)
      $rs[$key[$i]] = $value[$i];
    $this->conn[$regs[1]][] = $rs;
    $this->_close();
  }
  function _update($query) {
    eregi("update +([0-9a-z_]+) +set *(,?.*=.*)+( +where +(.+))",$query,$regs);
    $regs[2] = eregi_replace(",","=",$regs[2]);
    $v = split("=",$regs[2]);
    $keys = $this->_where($regs[4],"/$this->conn[$regs[1]]");
    while(list($key,$value) = each($keys)) {
      for($i=0;$i<count($v);$i+=2)
        $this->conn[$regs[1]][$value][$v[$i]] = eregi_replace("'","",$v[$i+1]);
    }
    $this->_close();
  }
  function _delete($query) {
    eregi("delete +from +([0-9a-z_]+) *(where +(.+))?",$query,$regs);
    $keys = $this->_where($regs[3],"/$this->conn[$regs[1]]");
    while(list($key,$value) = each($keys)) {
      unset($this->conn[$regs[1]][$value]);
    }
    reset($this->conn[$regs[1]]);
    while(list($key,$value) = each($this->conn[$regs[1]])) {
      $ch[] = $value;
    }
    $this->conn[$regs[1]] = $ch;
    $this->_close();
  }
  function _where($search,$table) {
    $search = eregi_replace("/("," ( ",$search);
    $search = eregi_replace("/)"," ) ",$search);
    $search = eregi_replace("/+"," + ",$search);
    $search = eregi_replace("/*"," * ",$search);
    while(eregi("[^ ]([*/><!=-])",$search,$regs)) {
      $search = eregi_replace($regs[1]," $regs[1] ",$search);
    }
    while(eregi("([><!] +=)",$search,$regs)) {
      $search = eregi_replace($regs[1],eregi_replace(" ","",$regs[1]),$search);
    }
    $search = eregi_replace("  "," ",trim($search));
    $search = eregi_replace(" and "," && ",$search);
    $search = eregi_replace(" or "," || ",$search);
    $search = eregi_replace(" = "," == ",$search);
    $ar = split(" ",$search);
    eval("/$t=$table;");

    for($i=0;$i<count($ar);$i++) {
      if(isset($t[0][$ar[$i]]))
        $ar[$i] = "/$value[".$ar][$i]."]";
    }
    $exPR = "/$expl=(".join(" ",$ar).");";
   
    while(list($key,$value) = each($t)) {
      eval($expr);
      if($expl)
        $keys[] = $key;
    }
    return $keys;
  }
  function _sort(&$ar,$key=0,$mode="desc") {
    global $cmp_key;
    $cmp_key = $key;
    if($mode == "asc")
      usort($ar,_cmp_asc);
    else
      usort($ar,_cmp_desc);
  }
  function _close() {
    $fp = fopen($this->database,"w");
    fwrite($fp,serialize($this->conn));
    fclose($fp);
  }
}

/** 排序鍵
*/
$cmp_key = "";

/** 排序用工作函數(降序 由usort()調用)
*/
function _cmp_desc($a,$b) {
  global $cmp_key;
  if ($a[$cmp_key] == $b[$cmp_key]) return 0;
  return ($a[$cmp_key] > $b[$cmp_key]) ? -1 : 1;
}

/** 排序用工作函數(升序 由usort()調用)
*/
function _cmp_asc($a,$b) {
  global $cmp_key;
  if ($a[$cmp_key] == $b[$cmp_key]) return 0;
  return ($a[$cmp_key] > $b[$cmp_key]) ? 1 : -1;
}
?>

測試例:
<pre>
<?php
//require_once "db_text.php";

$conn = new DB_text;
$conn->connect("text1.txt");

$conn->query("insert into manage (id,title) values (10,'abcd')");
$conn->query("insert into manage (id,title) values (2,'43d')");
$conn->query("insert into manage (id,title) values (20,'tuu')");
$conn->query("update manage set id=101,test='a' where id=10");
//$conn->query("delete from manage where id='10'");
//$conn->query("delete from manage where id=10 or table='code'");


//$rt = $conn->query("select * from manage where id=101 or table='code' group by 1 order by 1 asc");
$rt = $conn->query("select * from manage group by 1 order by id desc");

print_r($rt);

?>
</pre>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人综合亚洲| 4438全国亚洲精品在线观看视频| 宅男66日本亚洲欧美视频| 亚洲精品久久久久久久久久久久| 国产91成人在在线播放| 国产精品亚洲аv天堂网| 中日韩美女免费视频网址在线观看| 欧美激情一级欧美精品| 国产欧美一区二区三区久久人妖| zzjj国产精品一区二区| 日韩av在线影院| 欧美丰满少妇xxxxx| 国产精品日韩在线观看| 久久久久久国产精品三级玉女聊斋| 国产精品中文字幕在线观看| 欧美精品日韩三级| 久久久久久噜噜噜久久久精品| 2019国产精品自在线拍国产不卡| 96精品视频在线| 亚洲第五色综合网| 亚洲综合社区网| 欧美成人免费视频| 国产精品国语对白| 国产91精品视频在线观看| 欧美成人免费一级人片100| 久久久99久久精品女同性| 日本精品在线视频| 亚洲日本aⅴ片在线观看香蕉| 国产欧美精品xxxx另类| 九九热最新视频//这里只有精品| 国产亚洲一区精品| 国产精品扒开腿做爽爽爽视频| 日本在线观看天堂男亚洲| 岛国av一区二区| 欧美日韩综合视频网址| 日韩成人在线电影网| 亚洲视频777| 日本成人在线视频网址| 欧美日韩国产限制| 日韩女优人人人人射在线视频| 这里只有精品丝袜| 欧美精品一本久久男人的天堂| 欧美精品电影在线| 亚洲激情在线观看| 精品久久久久久久大神国产| 日韩精品福利在线| 欧美午夜激情在线| 日韩欧美国产一区二区| 国产一区二中文字幕在线看| 精品国产视频在线| 亚洲国产精品大全| 久久亚洲精品毛片| 日韩欧美精品网站| 亚洲第一福利在线观看| 日韩有码片在线观看| 国产91网红主播在线观看| 久久精品国产亚洲一区二区| 欧美中文字幕在线| 国产亚洲精品一区二555| 欧美日韩爱爱视频| 91精品在线国产| 亚洲精品www| 色偷偷9999www| 91精品在线影院| 国产视频一区在线| 国产精品狼人色视频一区| 中文字幕亚洲情99在线| 国产精品www| 亚洲黄色片网站| 国产精品久久久久久av下载红粉| 欧美xxxx做受欧美.88| 亚洲 日韩 国产第一| 久久精品人人做人人爽| 精品久久久久久久久久ntr影视| 日韩在线资源网| 中文字幕欧美专区| 亚洲色图欧美制服丝袜另类第一页| 国产精品吹潮在线观看| 国模视频一区二区三区| 国产一区二区三区在线观看视频| 成人免费视频网址| 26uuu亚洲国产精品| 日韩网站免费观看| 欧美天堂在线观看| 久久全国免费视频| 日韩在线免费视频观看| xxx欧美精品| 777777777亚洲妇女| 日韩美女视频中文字幕| 欧美华人在线视频| 亚洲天堂男人天堂女人天堂| 日韩视频永久免费观看| 久久精品国产99国产精品澳门| 欧美一级片在线播放| 92国产精品久久久久首页| 亚洲日韩欧美视频一区| 日本精品视频在线| 91最新国产视频| 亚洲精品免费一区二区三区| 国产视频精品va久久久久久| 狠狠色狠狠色综合日日小说| 精品久久久999| 亚洲一区二区三区乱码aⅴ蜜桃女| 日韩一级裸体免费视频| 久久精品国产69国产精品亚洲| 亚洲成人a级网| 色妞欧美日韩在线| 精品国内亚洲在观看18黄| 欧美高清不卡在线| 九九视频直播综合网| 亚洲欧美日韩一区在线| 国产做受高潮69| 日本精品性网站在线观看| 久久久国产精彩视频美女艺术照福利| 亚洲国产另类 国产精品国产免费| 亚洲美女福利视频网站| 久久成人精品视频| 久久精品亚洲94久久精品| 国产美女精品免费电影| 亚洲第一男人天堂| 国产精彩精品视频| 成人做爽爽免费视频| 欧美激情精品久久久久久大尺度| 中文字幕日韩有码| 国产亚洲欧美日韩美女| 伊人久久精品视频| 亚洲性无码av在线| 亚洲精品videossex少妇| 91精品综合视频| 欧美激情精品久久久| 亚洲最大中文字幕| 亚洲一区二区三区四区视频| 亚洲欧美中文在线视频| 成人午夜黄色影院| 欧美性黄网官网| 国产精品欧美日韩| 日韩av电影手机在线观看| 欧美一区二区三区免费观看| 日产精品99久久久久久| 国产91精品久久久久久| 亲爱的老师9免费观看全集电视剧| 国产亚洲欧洲高清一区| 欧美精品免费看| 亚洲欧美自拍一区| 激情亚洲一区二区三区四区| 国产日韩欧美黄色| 亚洲天堂第二页| 最近2019年日本中文免费字幕| 国产精品日日做人人爱| 亚洲天堂av网| 精品精品国产国产自在线| 日韩av免费在线观看| 5566成人精品视频免费| 国产亚洲欧洲高清| 97国产真实伦对白精彩视频8| 91免费视频国产| 日本高清+成人网在线观看| 在线色欧美三级视频| 欧美日韩一二三四五区| 欧美三级免费观看| 韩国19禁主播vip福利视频| 欧美日韩亚洲91| 亚洲成人激情在线| 亚洲人成在线一二|