YII2模型之增删改查

来源:互联网 发布:linux mysql删除数据库 编辑:程序博客网 时间:2024/05/22 12:04
1、ActiveRecord 类型的增删改查
以\app\models\Article 模型为准 , 来操作以下函数
1) 查询数据
①findAll 查询多条数据
\app\models\Article::findAll([‘status’ => ‘1’]); //查询 Article , status 为 1 的所有数据
②根据 findOne 进行查询 , 根式\app\models\Article::findOne(‘条件’);
\app\models\Article::findOne(1); //直接根据 id 查询
\app\models\Article::findOne([‘status’ => ‘1’]); //根据指定条件查询
③根据 find()进行查询 , find 可以连接查询
//查询一条 id 等于 1 的数据
\app\model\Article::find()->where([‘id’ => 1])->one();
//查询 status 等于 1 的所有数据
\app\model\Article::find()->where([‘status’ => ‘1’])->all();

\app\model\Article::find()->where(‘status=:status’ , [‘:status’ => ‘1’])->all();
//查询 status 等于 1 的所有数据 , 根据 date 排序
\app\model\Article::find()->where([‘status’ => ‘1’])->orderBy(‘date DESC’)->all();
//查询 status 等于 1 的数据 , 根据 date 排序 , 从第 5 条开始,读取 3 条
\app\model\Article::find()->where([‘status’=>‘1’])->orderBy(‘date DESC’)->offset(5) ->limit(3) ->all();
④更新一条数据
$article = \app\models\Article::findOne(1);
$article -> title = ‘change title’;
//save 函数第一个参数默认为 true , 就是更新或插入启动验证
//如果不想使用验证可以用 save(false);
$article -> save();
⑤更新指定属性 updateAll(‘更新的属性’ , ‘条件’ )
\app\models\Article::updateAll([‘title’ => ‘change title’ ] , [‘id’ => 1]);
⑥添加一条新数据
$article = new \app\models\Article();
$article -> title = ‘new one’;
$article -> content = ‘this is new’;

$article -> save();

⑦删除一条数据
\app\models\Article::findOne(1)->delete();
⑧删除指定条件的数据
\app\models\Article::deleteAll([‘id’ => 2]);
2、\yii\db\Query 查询数据
$db = new \yii\db\Query;
//查询一条 id 等于 2 的数据
$db->select('id')->from('mrs_article')->where("id=:id " , [':id' => 2])->one();
$db->select('id')->from('mrs_article')->where([‘id’ => 1])->one();
//查询多条
$db->select('id')->from('mrs_article')->where([‘status’ => ‘1’])->all();
//in 查询多条
$db->select('id')->from('mrs_article')->where([‘id’ =>[1,2]])->all();
//根据时间排序 ,并且从第 5 条开始获取 3 条
$db->select(‘id’)->from(‘mrs_article’)->orderBy(‘date DESC’)->offset(5)->limit(3)->all()
//查询数据总个数
$db->select('id')->from('mrs_article')->count();
3、Yii::$app->db 进行增删改查
① 查询数据
//查询一条数据
\Yii::$app->db->createCommand(“SELECT * FROM mrs_article”)->queryOne();
//绑定单个防注入参数
\Yii::$app->db->createCommand(“SELECT * FROM mrs_article where id=:id”)
->bindValue(“:id” , 2)->queryOne();
//绑定多个防注入参数
\Yii::$app->db->createCommand(“SELECT * FROM mrs_article where id=:id AND
status=:status”) ->bindValues([‘:id’ => 1 , ‘:status’ => ‘1’])->queryOne();
//查询多条数据
\Yii::$app->db->createCommand(“SELECT * FROM mrs_article”)->queryAll();
//查询指定数据的字段的数据
$db =\Yii::$app->db;
$db->createCommand(“SELECT COUNT(*) FROM mrs_article”)->queryScalar();
② 更新数据
$db = \Yii::$app->db->createCommand();
$db->update(‘mrs_article’ , [‘status’=>0] , “id=:id” , [‘:id’ => 1])->execute();
③插入数据
$db = \Yii::$app->db->createCommand();
$db->insert(‘mrs_article’ , [‘title’=>’new Record’] )->execute();

④删除数据
$db = \Yii::$app->db->createCommand();
$db->delete(‘mrs_article’ , “id=:id” , [‘:id’ => 1] )->execute();
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 新领的发票跟电脑对不上号怎么办 淘宝未发货退款卖家拒绝怎么办 在超市买东西把票丢了不让出怎么办 在淘宝上买东西付款不发货怎么办 买家拍下商品卖家拒绝发货怎么办 没有中文标签被投诉到工商局怎么办 淘宝申请退款卖家强制发货怎么办 1688卖家交易不小心关闭怎么办 拼多多两天不发货怎么办自动退款吗 在家里放的东西找不到了怎么办 在家里烧东西烟太大了怎么办 转转上买的二手东西有问题怎么办? 大巴车过虎门大桥错走小车道怎么办 pe高压膜中间松两边紧怎么办? 穿着浅口的高跟鞋走路老是掉怎么办 五吧同城模特兼职被骗了怎么办 华为手机充电玩黑屏怎么办教学视频 衣服肩膀被衣架撑变形了怎么办 货已经安到客户家客户不付款怎么办 微商卖家不给退货不给换货怎么办啊 淘宝卖家已签收退货却不退款怎么办 申请换货卖家收到货不给换怎么办 我买了个机器想退货怎么办 卖家要求退回去又拒收怎么办 拼多多48小时还不发货怎么办 退货退款单号填错了退不了款怎么办 淘宝退货退款快递单号填写错怎么办 蘑菇街退货忘记填快递单号了怎么办 您尝试购买的项目已停止供货怎么办 oppo新手机搬家搬了一半怎么办 开手机店手机卖不出去怎么办 京东买的东西误按签收了怎么办 小米5x充电宝充电自动断电怎么办 小米2s开不了机怎么办充电闪红灯 寄快递写错地址但已经发货了怎么办 拼多多发货时快递公司写错了怎么办 千牛发货信息写错了怎么办 发货物流单电话写错了怎么办 顺丰寄电脑保价后电脑进水了怎么办 微销通分享小程序没有二维码怎么办 京东的东西退掉但是赠品怎么办