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