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=guoyu')->limit('limit 1')->select();
//输出:select name,sex,address from test where name=guoyulimit 1
http://www.bkjia.com/phpjc/986703.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/986703.htmltecharticlephp连贯操作实现 我们在使用一些框架(如thinkphp)编码的时候,常用到这样的代码。 m(user)-where(array(id=1))-field(name)-select(); 这样不仅有利于编码...