06. Yii 2.0 数据库交互 - DAO

DAO(Data Access Objects 数据库访问对象)
Yii 包含了一个建立在 PHP PDO 之上的数据访问层 (DAO)。DAO为不同的数据库提供了一套统一的API。

示例:
以 Yii 2.0 基础版为例,高级版类似。
首先,在 basic 目录下新建一个文件夹 entity,然后在 basic/entity 目录下新建 basicUser.php 文件,里面封装了对 basic_user 表的 CURD 操作增、删、改、查),内容如下:

    
    db;    // 实例化一个db组件
        $sql = 'INSERT '.self::TABLE_NAME.'(username,passwd) VALUES("jack","123456")';
        $command = $db->createCommand($sql); 
        $command->execute();     // 执行sql语句,返回值为受影响的行数
        return $db->lastInsertID;    // 获取新增记录的主键id */

/*         // 通过面向对象编程的方式
        $res = \Yii::$app->db->createCommand()
                             ->insert(self::TABLE_NAME, array('username'=>'rose', 'passwd'=>'888888'))
                             ->execute();        // 新增操作,返回的是受影响的行数
        return \Yii::$app->db->lastInsertID; */

        // 同时插入多条记录
        // INSERT table_name(columns) VALUES(val1),(val2)
        $res = \Yii::$app->db->createCommand()
                             ->batchInsert(self::TABLE_NAME, array('username','passwd'), array(array('user1','111111'), array('user2','222222')))
                             ->execute();        
        return \Yii::$app->db->lastInsertID;    // 注意这里返回的是批量插入的第一条记录的主键id
    }

    /**
     * 删除记录
     */
    public function del(){
        $res = \Yii::$app->db->createCommand()
                             ->delete(self::TABLE_NAME, ['id'=>3])
                             ->execute();    // 删除操作,返回的是受影响的行数
        return $res;
    }

    /**
     * 更新记录
     */
    public function update(){
        $res = \Yii::$app->db->createCommand()
                             ->update(self::TABLE_NAME, ['username'=>'newuser'], ['id'=>2])
                             ->execute();    // 更改操作,返回的是受影响的行数
        return $res;
    }

    /**
     * 查询多条记录(查询操作是增、删、改、查中,最为复杂的操作)
     */
    public function query(){
        $sql = 'SELECT * FROM '.self::TABLE_NAME;
        $res = \Yii::$app->db->createCommand($sql)
                             ->queryAll();        // 返回二维数组
        return $res;
    }

    /**
     * 查询单条记录
     */
    public function getUserInfo($username){
/*         // 这种sql语句的写法不安全,容易引起sql注入
        $sql = 'SELECT * FROM '.self::TABLE_NAME.' WHERE username="'.$username.'"';
        $res = \Yii::$app->db->createCommand($sql)
                             ->queryOne();        // 返回一维数组
        return $res; */

        // 使用参数绑定,php的pdo扩展支持参数绑定的形式来书写sql,可预防sql注入
        $sql = 'SELECT * FROM '.self::TABLE_NAME.' WHERE username=:uname';  // 使用占位符 :uname
        $res = \Yii::$app->db->createCommand($sql)
                             ->bindValues(array(':uname'=>$username))    // 参数绑定
                             ->queryOne();        // 返回一维数组
        return $res;
        // 增、删、改、查操作,都可以使用参数绑定的方式,防止sql注入
    }

    /**
     * 事务的操作
     */
    public function trans(){
        $db = \Yii::$app->db;
        $trans = $db->beginTransaction();
        try {
            //...
            $trans->commit();
            return true;
        } catch (\Exception $e) {
            $trans->rollBack();
            return false;
        }
    }    
}
然后,修改数据库配置文件 basic/config/db.php,如下:

    
     'yii\db\Connection',
    'dsn' => 'mysql:host=localhost;dbname=test',
    'username' => 'root',
    'password' => '',
    'charset' => 'utf8',
];
再在MySQL数据库中新建一个数据库 test,创建数据表 basic_user,包含字段id、username、passwd。

最后,在 basic/controllers 目录下新建一个控制器 TestController.php,内容如下:

     
     add();
        var_dump($res);
    }

    /**
     * 删除记录
     */
    public function actionDel(){
        $res = (new BasicUser())->del();
        var_dump($res);
    }

    /**
     * 编辑记录
     */
    public function actionEdit(){
        $res = (new BasicUser())->update();
        var_dump($res);
    }

    /**
     * 查询多条记录
     */
    public function actionQuery(){
        $res = (new BasicUser())->query();
        echo json_encode($res);
    }

    /**
     * 查询单个用户信息
     */
    public function actionGetInfo(){
        $res = (new BasicUser())->getUserInfo('jack');
        var_dump($res);
    }
}
在浏览器地址栏分别访问以下地址,查看对应的效果:
http://basic.com/test/add
http://basic.com/test/del
http://basic.com/test/edit
http://basic.com/test/query
http://basic.com/test/get-info



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用: "ERROR org.springframework.boot.SpringApplication - Application run failed.yaml.snakeyaml.reader.ReaderException: special characters are not allowed" 这个错误信息说明在应用程序运行时出现了问题,具体是由于在YAML文件中使用了不允许的特殊字符导致的。特殊字符在YAML中通常是不被允许的,因为它们可能引发解析错误。需要检查YAML文件中是否存在特殊字符,并根据具体情况进行修改。 引用: "3.将数据库脚本导入到MySQL数据库服务器,在common\config下找到main-local.php修改数据库配置信息,‘dsn’为数据连接字符串,其中host为数据库地址,port为连接端口,dbname为数据库名称;‘username’为数据库..." 这个引用提到了将数据库脚本导入到MySQL数据库服务器,并修改数据库配置信息的步骤。在common\config文件夹下的main-local.php文件中,可以找到数据库的连接字符串和其他配置信息,例如数据库地址、连接端口、数据库名称以及数据库用户名等。根据需要,您可以修改这些配置信息以适应您的环境。 综上所述,出现"ERROR org.springframework.boot.SpringApplication - Application run failed"错误可能是由于YAML文件中使用了不允许的特殊字符导致的。您可以检查YAML文件并修改其中的特殊字符。另外,在修改数据库配置信息时,请确保按照提供的步骤将数据库脚本导入到MySQL数据库服务器,并在main-local.php文件中正确配置数据库连接字符串和其他相关信息。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [ERROR org.springframework.boot.SpringApplication - Application run failed org.yaml.snakeyaml.reader](https://blog.csdn.net/qq_47291002/article/details/129685984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [富盈国际微盘源码点位盘yii高端系列,包含原油期货盘,直播页面和完整运营版,内附安装说明](https://download.csdn.net/download/weixin_36643308/88251229)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值