Yii框架自定义数据库操作组件示例_php实例_脚本之家,Yii框架学习笔记之应用组件操作示例_php实例_脚本之家

接口类 appcomponentsCustomComponentCustomComponent;

针对DbOper 接口的实现类 DbRealization1.phpgetQueryObj->queryAll return $result; else return array(); } /** * interface @Override */ public function fetch($sql='',$keyVal=array return array(); $result = $this->getQueryObj->queryOne return $result; else return array(); } /** * interface @Override */ public function insert($tableName='',$values=array { if return 0; $insert = $this->getYiiDbConnection; if { $keys = array_keys; return $insert->batchInsert($tableName,$keys,$values)->execute(); } return $insert->insert->execute(); } /** * interface @Override */ public function update($tableName='',$where = '',$update=array { if return 0; if return 0; return $this->getYiiDbConnection ->update($tableName,$update,$where) ->execute(); } /** * interface @Override */ public function delete($tableName='',$where='') { if return 0; return $this->getYiiDbConnection ->delete ->execute(); } /** * 获得查询操作对象 * @return * Object */ private function getQueryObj($sql='',$keyVal=array { $query = $this->getYiiDbConnection()->createCommand; if $query->bindValues; return $query; } /** * interface @Override */ public function transcation { if return false; $db = $this->getYiiDbConnection(); $outerTransaction = $db->beginTransaction(); $runClient = true; try { foreach { $db->createCommand; } $outerTransaction->commit(); }catch{ $runClient = false; $outerTransaction->rollback(); } return $runClient; } /** * interface @Override */ public function getYiiDbConnection() { if { $this->db = Yii::$app->db; } return $this->db; }}

customComponent2,customComponent3 我们都让他们与customComponent1
具有相同的代码。 那么我们怎么去调用这些组件呢?

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

然后回过头看数组形式、函数形式、字符串形式的组件

array( 'components' => array( //自定义数据库操作组件 'dbOper' => array( 'class' => 'appcomponentsDbOperrealizationDbRealization1' ), //Yii 框架数据库连接组件 'db' => array( 'class' => 'yiidbConnection', 'dsn' => 'mysql:host=localhost;dbname=yii', 'username' => 'root', 'password' => '123456', 'charset' => 'utf8' ); ))

在应用目录下创建 components 目录

然后我们就可以通过 Yii::$app->dbOper 去操作数据库了。

//函数形式 - 这个很容易理解 实例化后设置属性值function(){ $custom = new appcomponentsCustomComponentrealizationCustomComponent1(); $custom->setName; $custom->setAge; return $custom; },//数组形式 - 它会实例化这个组件 之后设置属性值 注意这里设置属性值的方法 和 函数不一样,它是 $custom->name = '谭勇' , $custom->age = 22array( 'class' => 'appcomponentsCustomComponentrelazationCustomComponent2' 'name' => '谭勇', 'age' => 22 ),//字符串形式 只知道会实例化这个组件,怎么注入属性值,这个不清楚支不支持

将我的数据库操作组件注册进配置文件web.php 中

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

然后我们就可以在components 目录下定义我们的数据库操作类了。
因为,不知道怎么去获得php pdo
的原生操作对象,所以这里是对Yii数据库操作类的一个二次封装。

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

接口文件 DbOper.php 自定义的数据库操作类都得实现该接口

接口实现类
appcomponentsCustomComponentrealizationCustomComponent1

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

如果只是在components
中声明了该组件,那么只有在首次调用的时候才会实例化这个组件,之后调用都会复用之前的实例。
如果你在bootstrap
数组中声明了这个组件,那么该组件会随着应用主体的创建而实例(也就是默认会被实例,而不是首次调用才会实例这个组件)。

注意:我的自定义数据库操作类 依赖 Yii::$app->db 这个组件,
也就是框架自带的数据库连接组件

发表评论

电子邮件地址不会被公开。 必填项已用*标注