×Ô¼º¶¯ÊÖ×öÒ»¸öSQL½âÊÍÆ÷

6年以前  |  阅读数:339 次  |  编程语言:PHP 

×Ô¼º¶¯ÊÖ×oÒ»¸oSQL½aÊÍÆ÷
ÔÚÒ»Ð(C)СÐ͵ÄÓ¦ÓÃÖУ¬ÍeȫûÓбØҪʹÓôoÐÍÊý¾Ý¿aÈi¼þ¡£×Ô¼º×oÒ»¸oSQL½aÊÍÆ÷¾ÍÄÜÓÃÊý¾Ý¿aµÄ*½Ê½À´¹ÜÀiÁË¡£
Õa¸o½aÊÍÆ÷£¬ÄܽaÊͳ£ÓõÄSQLÃuÁi¡£Äa¿ÉÒÔ×ÔÐÐÌi¼ÓÆaËu¹¦ÄÜ¡£

<?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µÄ¸¨Öuº¯Êý
    /
    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);
}
}

/* ÅÅÐo¼u
/
$cmp_key = "";

/* ÅÅÐoÓù¤×÷º¯Êý(½µÐo ÓÉ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;
}

/* ÅÅÐoÓù¤×÷º¯Êý(ÉýÐo ÓÉ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;
}
?>

²aÊÔÀý£º

  
$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);

?>

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
文件下载
获取IMEI
贪吃蛇
双位运算符
发送邮件
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
提取后缀名
年的日历图
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例