本文实例讲述了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 目录下定义我们的数据库操作类了。 因为,不知道怎么去获得php pdo 的原生操作对象,所以这里是对Yii数据库操作类的一个二次封装。
接口文件 DbOper.php 自定义的数据库操作类都得实现该接口
<?php namespace app\components\DbOper; /** * 自定义数据库操作组件 依赖系统定义组件db */ interface DbOper { /** * 查询多条数据 * @param * String $sql 需要查询的sql语句 * array $keyVal 字段映射 * @return * array 查询结果 */ public function fetchAll($sql='',$keyVal=array()); /** * 查询一条数据 原生sql * @param * String $sql 需要查询的sql语句 * array $keyVal 字段映射 * @return * array 查询结果 */ public function fetch($sql='',$keyVal=array()); /** * 添加数据 * @param * String $tableName 表名 * array $values 要插入的数据 * @return * int 受影响的行数 */ public function insert($tableName='',$values=array()); /** * 更新数据 * @param * String $tableName 表名 * array | String $where 修改条件 为 1 时更改该表所有的行 * array $update 要更新的数据 * @return * int 受影响的行数 */ public function update($tableName='',$where='',$update=array()); /** * 删除数据 * @param * String $tableName 表名 * array | String $where 删除条件 * @return * int 受影响的行数 */ public function delete($tableName='',$where=''); /** * 事务处理 * @param * array $sqls 要执行的sql集合 * return * boolean 是否执行成功 */ public function transcation($sqls = array()); /** * 获得数据库链接 */ public function getYiiDbConnection(); }
针对DbOper 接口的实现类 DbRealization1.php