请教 eloquent 中 update 构造器的值指定的表名.字段名应该怎么写?

关联table1,table2,把符合条件table1.price的值更新为table2.price的值
table1::join('table2', 'table1.id', '=', 'table2.id) ->where('table1.price', '<', 'table.price') ->update([ 'table1.price' => 'table2.price' ]);
尝试这样写'table2.price'为这串字符串,不是表.字段名
使用`包裹或者'table1.price=>DB::Raw('table2.price')同样不行

请问怎样才能让update的值设定为表.字段名而不是字符串。

《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
最佳答案

查了半天,原来是where('table1.price', '<', DB::raw('table.price')) where中的右边条件有表.字段也要使用raw。
低级错误 :joy:

5年前 评论
讨论数量: 1

查了半天,原来是where('table1.price', '<', DB::raw('table.price')) where中的右边条件有表.字段也要使用raw。
低级错误 :joy:

5年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!