Yii deleteByAttributs 用法,慎用Dao的delete
发布:smiling 来源: PHP粉丝网 添加日期:2014-01-08 14:59:17 浏览: 评论:0
Yii框架一定要慎用Dao的delete,一不小心它生不成条件的话,就变成了整表删除,可以用ActiveRecord的deleteByAttributes或deleteAll方法相对不容易写错。
deleteByAttributes用法如下:
- MyClass::model()->deleteAllByAttributes(array(
- 'phone_number'=>$phoneNumber,
- ));
或者第一个参数为空,使用第二个条件参数,代码如下:
- MyClass::model()->deleteAllByAttributes(array(),'`phone_number` = :phone_number',array(
- ':phone_number'=>$phoneNumber,
- ));
或者使用deleteAll():,代码如下:
- MyClass::model()->deleteAll('`phone_number` = :phone_number',array(
- ':phone_number'=>$phoneNumber,
- ));
再来一个带in条件的,代码如下:
- $condition = new CDbCriteria();
- $condition->addCondition('status=:status');
- $condition->params = array(':status'=>1);
- $condition->addInCondition('user_id',array(100111,100221,100221));
- User::model()->deleteAll($condition);Dao带in条件的示例
- Yii::app()->db->createCommand()
- ->delete('mw_user', array('and', 'user_id=:user_id', array('in', 'position_id', array(1,2,3))),array(':user_id'=>121111));
但是请慎用DAO的delete,当你的条件写错一点,它将无法生成where条件,同时sql语句中也没有了where,但还不一定报错,结果就成了没有where的delete,结果会是整表被删除了.
Tags: deleteByAttributs 用法
相关文章
- ·YII路径的用法总结(2021-03-19)
- ·yii中widget的用法(2021-05-02)
- ·Yii中表单用法实例详解(2021-07-03)
- ·CI(CodeIgniter)模型用法实例分析(2021-07-06)
- ·Laravel中10个有用的用法小结(2021-11-21)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)