如何解决Laravel使用where条件更新记录
我有一个表(退款),其中的字段名为"num_pre"
,我需要在所有行中插入"num_pre"
等于NULL
的特定累进代码。例如,仅当"J0620222"
为"J0620223"
num_pre
然后null
等
我以为是这样
$data = Refunds::where('num_pre','=',"")->update(array('num_pre' => ????));
但是我不能,因为我需要foreach来创建渐进代码... 谢谢
解决方法
首先获取num_pre
为null的所有记录:
$records = Refund::whereNull('num_pre')->get();
然后,循环浏览所有记录并更新该列:
foreach($records as $record){
$record->num_pre = 'Your new progressive code';
$records->save();
}
PS:不确定您如何生成渐进代码,因为您没有在问题中提到它。
,Refund::where('num_pre',NULL)->update('field_of_progressive_code',$progressiveCode);
这相当于UPDATE refunds SET field_of_progressive_code = '$progressiveCode' WHERE num_pre = NULL
这将使用给定的代码更新所有递进代码为NULL的行。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。