程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php連貫操作實現

php連貫操作實現

編輯:關於PHP編程

php連貫操作實現


我們在使用一些框架(如ThinkPHP)編碼的時候,常用到這樣的代碼。
M('User')->where(array('id'=>1))->field('name')->select();
這樣不僅有利於編碼,而且也能讓人"心情愉悅"呢。好了,不多說了。讓我們看看如何實現的吧?
//數據庫操作基類[PS:主要功能連貫功能實現]
class Db{
//此屬性定義要實現連貫操作的方法名
public $sql = array(
"field" => "",
"where" => "",
"order" => "",
"limit" => "",
"group" => "",
"having" => "",
);

/**
* 連貫操作時,調用field() where() order() limit() group() having()方法且組合成sql語句
* 此方法為PHP魔術方法,調用類中不存在的方法時就會自動調用此方法
* @param $methodName 調用不存在的方法時,接收這個方法名稱的字符串
* @param $args 調用不存在的方法時,接收這個方法的參數,以數組形式接收
*/
function __call($methodName,$args){
//把要請求的方法名,統一轉為小寫
$methodName=strtolower($methodName);
//若請求方法名與成員屬性數組$sql下標對應上;則將第二個參數,賦值給數組中"下標對應的元素"

if(isset($this->sql[$methodName])){
$this->sql[$methodName]=$args[0];
}else{
echo '調用類'.get_class($this).'中的'.$methodName.'()方法不存在';
}
//返回對象;從而可以繼續調用本對象中的方法,形成連貫操作
return $this;
}

/**
* 用此方法拼接成一個select的sql語句;[PS:此方法終結了連貫操作,置於連貫操作的最後面]
*/
function select(){
//按照select語法拼接sql字符串[PS:可以在mysql命令行中執行"help select;"查看其語法構結]
$sql="SELECT {$this->sql['field']} FROM test {$this->sql['where']} {$this->sql['group']} {$this->sql['having']} {$this->sql['order']} {$this->sql['limit']}";
echo $sql;
}
}

$obj=new db();

$obj->field('name,sex,address')->where('where name="gongwen"')->limit('limit 1')->select();

//輸出:SELECT name,sex,address FROM test where name=gongwen limit 1

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved