【Laravel】关于Laravel8使用MySQL时字段加1的方法

前言:

在使用 Laravel8 的查询构造器来进行数据库查询的时候,往往需要将某个字段加减1,或者加减n,这个时候可以使用自带的 increment() | decrement() 接口,但是如果想使用 update() 接口的时候就不能和 increment() | decrement() 接口同时使用,所以字段加减需要使用原生语句。

代码:

class test
{
    // 数据库表名
    const TABLE_NAME = 'table_name';

    public function test() : void
    {
        $condition = [['id', '1']];

        // 传递参数时,使用原生语句 DB::raw(your_query);
        $updateData = ['login_times' => DB::raw('login_times + 1')];
        
        $result = DB::table(self::TABLE_NAME)
            ->where($condition)
            ->update($updateData);
    }
}

如果不使用 DB::raw(); 语句,而直接使用 key = key + 1 会出现

A non-numeric value encountered 错误。

例:

// 错误例 
$updateData = ['login_times' => 'login_times' + 1];

// 正确例
$updateData = ['login_times' => DB::raw('login_times + 1')];

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值