Yii框架学习笔记之应用组件操作示例_php实例_脚本之家

本文实例讲述了Yii框架学习笔记之应用组件操作。分享给大家供大家参考,具体如下:

本文实例讲述了Yii框架自定义数据库操作组件。分享给大家供大家参考,具体如下:

所有的组件都应声明在config/web.php

Yii 的数据库操作对象提供的方法确实很方便。
但是有的时候我们已经习惯了我们以前编写php的数据库操作语法,没有那么多时间去仔细看每个Yii提供的数据库操作语法,怎么办呢?
那就是一边学习,一边二次封装自己习惯的数据库操作类。
以后我们使用数据库操作对象,就用我们自己定义的组件去操作。

//组件声明在该数组下'components'=>array( //自定义组件1 - 函数形式 'customComponent1' => function(){ $custom = new app\components\CustomComponent\realization\CustomComponent1(); $custom->setName; $custom->setAge; return $custom; }, //自定义组件2 - 数组形式 'customComponent2' => array( 'class' => 'app\components\CustomComponent\relazation\CustomComponent2' 'name' => '谭勇', 'age' => 22 ), //自定义组件 - 字符串形式 'customComponent3' => 'app\components\CustomComponent\realization\CustomComponent3'),

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

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

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' ); ))
//默认加载customComponent1 和 customComponent2 组件'bootstrap' => array( 'customComponent1','customComponent2'),

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

在应用目录下创建 components 目录

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

组件 CutomComponent

针对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; }}

接口类 app\components\CustomComponent\CustomComponent;

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

接口实现类
app\components\CustomComponent\realization\CustomComponent1

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

相关文章

Comment ()
评论是一种美德,说点什么吧,否则我会恨你的。。。