Yii框架自定义数据库操作组件示例
本文实例讲述了Yii框架自定义数据库操作组件。分享给大家供大家参考,具体如下:
Yii的数据库操作对象提供的方法确实很方便。但是有的时候我们已经习惯了我们以前编写php的数据库操作语法,没有那么多时间去仔细看每个Yii提供的数据库操作语法,怎么办呢?那就是一边学习,一边二次封装自己习惯的数据库操作类。以后我们使用数据库操作对象,就用我们自己定义的组件去操作。
将我的数据库操作组件注册进配置文件web.php中
array( 'components'=>array( //自定义数据库操作组件 'dbOper'=>array( 'class'=>'app\components\DbOper\realization\DbRealization1' ), //Yii框架数据库连接组件 'db'=>array( 'class'=>'yii\db\Connection', 'dsn'=>'mysql:host=localhost;dbname=yii', 'username'=>'root', 'password'=>'123456', 'charset'=>'utf8' ); ) )
然后我们就可以在components目录下定义我们的数据库操作类了。因为,不知道怎么去获得phppdo的原生操作对象,所以这里是对Yii数据库操作类的一个二次封装。
接口文件DbOper.php自定义的数据库操作类都得实现该接口
针对DbOper接口的实现类DbRealization1.php
getQueryObj($sql,$keyVal)->queryAll(); if($result) return$result; else returnarray(); } /** *interface@Override */ publicfunctionfetch($sql='',$keyVal=array()) { if($sql==='') returnarray(); $result=$this->getQueryObj($sql,$keyVal)->queryOne(); if($result) return$result; else returnarray(); } /** *interface@Override */ publicfunctioninsert($tableName='',$values=array()) { if($tableName==='') return0; $insert=$this->getYiiDbConnection()->createCommand(); if(is_array($values[0])) { $keys=array_keys($values[0]); return$insert->batchInsert($tableName,$keys,$values)->execute(); } return$insert->insert($tableName,$values)->execute(); } /** *interface@Override */ publicfunctionupdate($tableName='',$where='',$update=array()) { if($tableName==='') return0; if($where==='') return0; return$this->getYiiDbConnection() ->createCommand() ->update($tableName,$update,$where) ->execute(); } /** *interface@Override */ publicfunctiondelete($tableName='',$where='') { if($tableName==='') return0; return$this->getYiiDbConnection() ->createCommand() ->delete($tableName,$where) ->execute(); } /** *获得查询操作对象 *@return *Object */ privatefunctiongetQueryObj($sql='',$keyVal=array()) { $query=$this->getYiiDbConnection()->createCommand($sql); if(!empty($keyVal)) $query->bindValues($keyVal); return$query; } /** *interface@Override */ publicfunctiontranscation($sqls=array()) { if(empty($sqls)) returnfalse; $db=$this->getYiiDbConnection(); $outerTransaction=$db->beginTransaction(); $runClient=true; try { foreach($sqlsas$sql) { $db->createCommand($sql)->execute(); } $outerTransaction->commit(); }catch(\Exception$e){ $runClient=false; $outerTransaction->rollback(); } return$runClient; } /** *interface@Override */ publicfunctiongetYiiDbConnection() { if($this->db===null) { $this->db=Yii::$app->db; } return$this->db; } }注意:我的自定义数据库操作类依赖Yii::$app->db这个组件,也就是框架自带的数据库连接组件
然后我们就可以通过Yii::$app->dbOper去操作数据库了。
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。