線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1182
推到 Plurk!
推到 Facebook!

自己動手做一個SQL解釋器PHP實例

 
conundrum
尊榮會員


發表:893
回覆:1272
積分:643
註冊:2004-01-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-01-20 14:42:27 IP:61.221.xxx.xxx 未訂閱
http://www.knowsky.com/2551.html    自己動手做一個SQL解釋器    [本頁面推薦在1024x768分辯率下瀏覽] 文章類別:PHP實例   發表日期:2002-3-24  星期日 自己動手做一個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;$iconn[$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;$iconn[$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("[^ ]([*/>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; } ?> 測試例:
<?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);    ?>
系統時間:2024-05-07 0:53:20
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!