php面向对象之-魔术方法在框架中的应用(自动生成sql语句)-127
2014-08-19 11:01
776 查看
<?php //02.php /**** 燕十八 公益PHP讲堂 论 坛: http://www.zixue.it 微 博: http://weibo.com/Yshiba YY频道: 88354001 ****/ /*** ====笔记部分==== ***/ /* 刚才 我们用TP做了一个用户注册,注册时的代码在下面 按我们以前的做法, 把POST来的数据,拼接sql,然后查询. 但是在TP中的做法,有点奇怪, 他是把收到的信息, 赋给了一个对象的属性. 然后对象->add()方法,就写入到数据库了. 很方便 . 思考: 1: userModel就有username属性供你去赋值吗? 2: 如果$userModel->xxx属性,是保护的, 而我的表,又有一个字段,恰好也叫xxx, 那么 我自然是 $user->xxx = $_POST['xxx']; 这不就出错了吗? 3:还有一个问题: userModel 有一些属性,很正常,比如有5个属性 a,b,c,d,e 我在注册时, 又动态设置了属性, f,g,h,i 疑问: 在拼接sql时,要把a,b,c,d,e忽略掉才行. 又怎么忽略. 答:用魔术方法来解决 通过__set()方法, 把属性的设置--->都放到数组里. 处理时,专门处理这个数组就可以了. 这样,就不会和其他属性相冲突 */ /* TP中的一段用户注册代码 $userModel->username = $_POST['username']; $userModel->email = $_POST['email']; if($num = $userModel->table('user')->add()) { echo '注册成功'; } else { echo 'fail'; } */ class UserModel { protected $email = 'user@163.com'; protected $data = array(); public function __set($k,$v) { // $this->$k = $v; //并没有真正赋成自己的属性 $this->data[$k] = $v; // 而是放在一个数组里 } public function __get($p) { return isset($this->data[$p]) ? $this->data[$p] : NULL; } public function __unset($p) { unset($this->data[$p]); } public function __isset($p) { return isset($this->data[$p]); } public function add() { $sql = 'insert into table ('; $sql .= implode(',',array_keys($this->data)); $sql .= ') values (\''; $sql .= implode("','",array_values($this->data)); $sql .="')"; return $sql; } } echo '<pre>'; $userModel = new UserModel(); print_r($userModel); $userModel->username = 'lisi'; $userModel->email = 'lisi@126.com'; print_r($userModel); //echo $userModel->add(); unset($userModel->email); print_r($userModel); ?>
相关文章推荐
- PB中自动生成的sql语句,在comment不存在时,自动使用name字段作为注释的设置方法
- php实现解析xml并生成sql语句的方法
- PHP面向对象 1.7 常见的魔术方法及应用
- php-自动生成sql语句
- thinkphp如何查看方法自动sql生成的sql语句
- php之魔术方法在框架的应用
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- J2EE中SQL语句自动构造方法
- 实体类自动生成SQL插入执行语句
- 自动生成清空数据库的SQL语句
- 关于SQL语句的自动生成!(四)
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- 多条件搜索时sql语句的自动生成
- 关于SQL语句的自动生成!(三)
- J2EE程序中的SQL语句自动构造方法
- 关于SQL语句的自动生成!(五)
- J2EE程序中的SQL语句自动构造方法
- J2EE程序中的SQL语句自动构造方法
- J2EE程序中的SQL语句自动构造方法
- ASP.NET基础教程-使用CommandBuilder对象自动生成SQL语句对数据进行批量更新