dswqz24846 2013-07-16 15:22
浏览 291

使用Yii中的updateAll方法通过某个数字更新字段值

I am a beginner in Yii framework. I have got a situation where i need to do like this

I have a column rgt in database and i want to increment that by 2 in some conditions.

I have written like these

Category::model()->updateAll( array("rgt"=>"rgt+2"),array("condition"=>"rgt >".$this->myRight));

this is not working. I am not sure what i wrote is right. Please help me

Thanks in advance

  • 写回答

1条回答 默认 最新

  • dsw1608 2013-07-17 06:54
    关注

    You can't pass DB expressions like rgt+2 to updateAll(). It will try to set this as column value and probably fail, as the column is of type INT. But you could use updateCounters() instead:

    Category::model()->updateCounters(array(
        'rgt' => 2,
    ), 'rgt > '.$this->myRight);
    
    评论

报告相同问题?

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分