当前位置:首页 > CMS教程 > 其它CMS > 列表

Yii deleteByAttributs 用法,慎用Dao的delete

发布:smiling 来源: PHP粉丝网  添加日期:2014-01-08 14:59:17 浏览: 评论:0 

Yii框架一定要慎用Dao的delete,一不小心它生不成条件的话,就变成了整表删除,可以用ActiveRecord的deleteByAttributes或deleteAll方法相对不容易写错。

deleteByAttributes用法如下:

  1. MyClass::model()->deleteAllByAttributes(array
  2.     'phone_number'=>$phoneNumber
  3. )); 

或者第一个参数为空,使用第二个条件参数,代码如下:

  1. MyClass::model()->deleteAllByAttributes(array(),'`phone_number` = :phone_number',array
  2.  
  3.     ':phone_number'=>$phoneNumber
  4. )); 

或者使用deleteAll():,代码如下:

  1. MyClass::model()->deleteAll('`phone_number` = :phone_number',array
  2.     ':phone_number'=>$phoneNumber
  3. )); 

再来一个带in条件的,代码如下:

  1. $condition = new CDbCriteria(); 
  2. $condition->addCondition('status=:status'); 
  3. $condition->params = array(':status'=>1); 
  4. $condition->addInCondition('user_id',array(100111,100221,100221)); 
  5. User::model()->deleteAll($condition);Dao带in条件的示例 
  6. Yii::app()->db->createCommand() 
  7. ->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 用法

分享到: