<?php namespace app\models; use yii\db\ActiveRecord; class MyUser extends ActiveRecord { public static function tableName() { return '{{%user}}'; } }
常用操作如下:
// 查询一条记录 // asArray的作用是以数组形式返回结果 // find()会返回一个ActiveQuery对象,ActiveQuery对象继承自yii\db\Query,所以可以使用Query中的所有查询方法 $data1 = MyUser::find()->where(['id' => 1])->asArray()->one(); // 查询多条记录 $data2 = MyUser::find()->where([])->orderBy('id desc')->asArray()->all(); // 根据主键获取一条记录 $data3 = MyUser::findOne(3); // 根据主键获取多条记录 $data4 = MyUser::findAll([4, 5, 6, 7]); // 带条件查询多条记录 $data5 = MyUser::findAll(['sex' => 1]); // 运行原生SQL $data6 = MyUser::findBySql('select * from {{%user}} where id=:id', [':id' => 8])->asArray()->one(); // 添加数据 // 准备一个新的实例,然后设置对应字段属性,保存 $user = new MyUser(); $user->name = 'test'; $user->sex = 1; $user->age = 22; $user->save(); // 修改数据 // 先获取一个对象,然后设置对应字段属性,保存 $upd = MyUser::findOne(10); $upd->name = 'abcdefg'; $upd->save(); // 修改多条数据 $data7 = MyUser::updateAll(['name' => 'update'], ['sex' => 1]); // 删除一条数据 $del = MyUser::findOne(15); $del->delete(); // 删除多条数据 $data8 = MyUser::deleteAll(['sex' => 0]); // 事务操作 $user2 = MyUser::findOne(22); $user3 = MyUser::findOne(33); $trans = MyUser::getDb()->beginTransaction(); try { $user2->name = '2222'; $user3->name = '3333'; //修改数据 $user2->save(); $user3->save(); $trans->commit(); } catch (\Exception $e) { $trans->rollBack(); throw $e; }
具体更多的操作方式建议查看官方文档。
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。