在Laravel外使用Eloquent如何写两个字段值相等的记录?
曾经蜡笔没有小新
曾经蜡笔没有小新 2017-05-16 16:52:34
[PHP讨论组]

要实现 select * from table where userid=parentid and age>30 这种查询应该如何写?没有在文档里找到这种用法.

曾经蜡笔没有小新
曾经蜡笔没有小新

全部回复(4)
阿神

方法一

$results = Model::whereRaw('userid=parentid and age>30')->get();

方法二

$results = DB::table('table_name')->whereRaw('userid=parentid and age>30')->get();
仅有的幸福

@ty0716 说的是标准答案。

我来补充一下,为什么会这样。
你的需求是,需要引用parentid作为where的右值,但是,在laravel中,where的右值,不能为sql,只能是常规的数据结构,例如字符串、数值、时间等。而不能是一个字段名(users.id)之类的有sql功能的东西,这是为了防止sql注入。

所以,只能使用@ty0716所说的raw方法来执行原生的sql了。

过去多啦不再A梦

没人知道吗?

PHPz
$model->where('userid','parentid')->where('age','>',30)->get();
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号