dongqiao1888 2018-01-17 20:56
浏览 10
已采纳

使用CakePHP 3中的查询将一个添加到整数列

I dont recall exactly how, but I do remember being able to add one to an integer column in mysql with a query without knowing the value of that integer column...

something like

update table set column=column+1 where id=1

I am wondering, how can I do the above query with CakePHP 3

  • 写回答

1条回答 默认 最新

  • dongshi6710 2018-01-17 23:12
    关注

    You can use \Cake\ORM\Table::updateAll() (or the underlying \Cake\Database\Query::update()), and use an expression to generate the arithmetic operation part, something like:

    $additionExpression = $Table->query()->newExpr('column + 1');
    
    $affectedRows = $Table->updateAll(
        ['column' => $additionExpression],
        ['id' => 1]
    );
    

    Or a little more complex in case you want to make use of automatic identifier quoting:

    $additionExpression = $Table
        ->query()
        ->newExpr()
        ->add([
            new \Cake\Database\Expression\IdentifierExpression('column'),
            '1'
        ])
        ->setConjunction('+'); // tieWith() before CakePHP 3.4
    

    See also

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题