Eloquent: Calling Where on a relation(Eloquent:在关系上调用 Where)
问题描述
我有以下 Eloquent ORM 查询.
I have the following Eloquent ORM query.
$products2 = Product::with('metal', 'metal.fixes', 'metal.fixes.currency')
->where('metal_id', '=', 1)
->get()->toArray();
此查询的输出如下:
http://pastebin.com/JnDi7swv
我希望进一步缩小查询范围,只显示fixes.currency_id = 1
的产品.
I wish to further narrow down my query to only display products where fixes.currency_id = 1
.
$products2 = Product::with('metal', 'metal.fixes', 'metal.fixes.currency')
->where('metal_id', '=', 1)
->where('metal.fixes.currency_id', '=', 1)
->get()->toArray();
有人可以帮我解决这个问题吗,因为我收到以下错误:
Could somebody help me with this second where please because I am getting the following error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'metal.fixes.currency_id'
in 'where clause' (SQL: select * from `products` where `metal_id` = ?
and `metal`.`fixes`.`currency_id` = ?) (Bindings: array ( 0 => 1, 1 => 1, ))
在 Rob Gordijn 的帮助下解决了:
Solved with the help of Rob Gordijn:
$products2 = Product::with(array(
'metal',
'metal.fixes.currency',
'metal.fixes' => function($query){
$query->where('currency_id', '=', 1);
}))
->where('common', '=', 1)
->where('metal_id', '=', 1)
->get()->toArray();
推荐答案
您正在寻找Eager Load Constraints":http://laravel.com/docs/eloquent#querying-relations
You are looking for "Eager Load Constraints": http://laravel.com/docs/eloquent#querying-relations
<?php
$products2 = Product::with(array('metal', 'metal.fixes', 'metal.fixes.currency' => function($query){
$query->where('currency_id', '=', 1);
}))
->where('metal_id', '=', 1)
->get()->toArray();
这篇关于Eloquent:在关系上调用 Where的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Eloquent:在关系上调用 Where
基础教程推荐
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01