我知道我可以使用此查询减少laravel中的列值
DB::table('users')->decrement('Votes', 5);
但我想限制价值成为负值.
无论如何用laravel做到这一点?
解决方法:
您需要使用原始查询.
以下代码应该为所有支持GREATEST功能的数据库引擎提供技巧:
DB::table('users')->update(['Votes' => DB::raw('GREATEST(Votes - 5, 0)')]);
它会将用户表中的投票列减少5,但不会低于零 – 这就是GREATEST函数的用途.