php連貫操作實現

來源:互聯網
上載者:User
我們在使用一些架構(如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



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.