###

今天在连表获取数据的时候,老是获取不到想要的,确实有点无力适从的感觉。

归根到底,还是对laravel不够熟悉,至少是数据库操作那块。

###

问题是这样的:

    我想要通过连表中间表,拿中间表的id。但是product 在关联的中间表中有多个,需要brandId,categoryId去限制获取,然后就可以获取到,但是我实际操作的时候却不是想要的结果。

获取的是categoryId=50 ,brand_id=1 的所有商品,还有需要中间表的id

array:10 [0 => array:21 ["id" => 323
"name" => ""
"snumber" => ""
"number" => 0
"product_categories" =>
      0 => array:6 [
"id" => 20
"product_id" => 323
"category_id" => 2
"brand_id" => 1
"created_at" => "2017-04-17 13:16:42"
"updated_at" => "2017-04-17 13:16:42"
]
1 => array:6 [
"id" => 458
"product_id" => 323
"category_id" => 1
"brand_id" => 1
"created_at" => "2017-04-17 15:40:34"
"updated_at" => "2017-04-17 15:40:34"
]
2 => array:6 [
"id" => 758
"product_id" => 323
"category_id" => 50
"brand_id" => 1
"created_at" => "2017-04-17 17:21:30"
"updated_at" => "2017-04-17 17:21:30"
]
3 => array:6 [
"id" => 991
"product_id" => 323
"category_id" => 47
"brand_id" => 1
"created_at" => null
"updated_at" => null
]
]
] 1 => array:21 [] 2 => array:21 [] 3 => array:21 [] 4 => array:21 [] 5 => array:21 [] 6 => array:21 [] 7 => array:21 [] 8 => array:21 [] 9 => array:21 [] ]

我只想要的是product_categories 中的第2个数组就行

方法是:

 $productIds = ProductCategories::where('category_id', $categoryId)
->where('brand_id', $brandId)
->pluck('product_id', 'id')
->all(); $products = Product::whereIn('id', $productIds)
->with('productCategories')
->whereHas('productCategories', function ($q1) use ($categoryId, $brandId) {
return $q1->where(['brand_id' => $brandId,'category_id' => $categoryId]);
})
->get();

发现这样操作并不行。。。

搞好久还是老实的去看文档

        $productIds = ProductCategories::where('category_id', $categoryId)
->where('brand_id', $brandId)
->pluck('product_id', 'id')
->all();
$products = Product::whereIn('id', $productIds)
->with(['productCategories' => function ($q1) use ($categoryId, $brandId){
$q1->where(['brand_id' => $brandId ,'category_id' => $categoryId]);
}])
->get();

结果就可以了:

array:10 [
0 => array:21 [
"id" => 323
"name" => ""
"snumber" => ""
"number" => 0
    "product_categories" => array:1 [
0 => array:6 [
"id" => 758
"product_id" => 323
"category_id" => 50
"brand_id" =>
"created_at" => "2017-04-17 17:21:30"
"updated_at" => "2017-04-17 17:21:30"
]
]
]

Laravel 5.2数据库--多个关联关系,带条件约束的渴求式加载的问题的更多相关文章

  1. Laravel渴求式加载(比较容易理解理解load与with关系)

    渴求式加载 当以属性方式访问 Eloquent关联关系的时候,关联关系数据是「懒惰式加载」的,这意味着关联关系数据直到第一次访问的时候才被加载.不过,Eloquent 还可以在查询父级模型的同时「渴求 ...

  2. laravel 嵌套的渴求式加载

    今天在通过需求表A查询场地类型表B,然后通过表B的场地类型id去查询表C场地类型名的时候遇到了一个小的问题. 需求表A的字段:id.user_id .name等等: 中间表B的字段:id.appeal ...

  3. laravel with嵌套的渴求式加载

    今天在通过需求表A查询场地类型表B,然后通过表B的场地类型id去查询表C场地类型名的时候遇到了一个小的问题. 需求表A的字段:id.user_id .name等等: 中间表B的字段:id.appeal ...

  4. laravel with 渴求式加载指定字段

    在使用 Laravel 的关联查询中,我们经常使用 with 方法来避免 N+1 查询,但是 with 会将目标关联的所有字段全部查询出来,对于有强迫症的我们来说,当然是不允许的. 这时候我们可以使用 ...

  5. 页面ajax自带的访问后台时,正在加载中

    ajax自带访问后台时,提示正在加载中,加载完成后自动消除遮罩层,代码如下: var mask=mui.createMask();//遮罩层 //传统ajax的post请求方式 mui.ajax('h ...

  6. 带你剖析WebGis的世界奥秘----瓦片式加载地图(转)

    带你剖析WebGis的世界奥秘----瓦片式加载地图 转:https://zxhtom.oschina.io/zxh/20160805.html  编程  java  2016/08/05 0留言,  ...

  7. 提取数据库字段里面的值,并改变+图片懒加载,jquery延迟加载

    要求:手机端打开某个页面的详细信息,因为网速或者别的原因,响应太慢,因为图片大的原因,希望先进来,图片在网页运行的情况再慢慢加载(jquer延迟加载) http://www.w3cways.com/1 ...

  8. 带你剖析WebGis的世界奥秘----瓦片式加载地图

    WebGIS应用程序的页面能够通过HTML.JSP.ASP或任何任何类型的Web页文件构成,其特殊之处在于,它的请求提交的方法并不是通过常用的 "超链接"形式,而是使用鼠标与Web ...

  9. EularProject 43: 带条件约束的排列组合挑选问题

    Sub-string divisibility Problem 43 The number, 1406357289, is a 0 to 9 pandigital number because it ...

随机推荐

  1. retry示例

    #!/usr/bin/python2.7 # -*- coding: utf-8 -*- import time import exceptions def func(): # a,b = None ...

  2. Android五大布局

    原文地址:http://blog.51cto.com/liangruijun/632532 https://www.cnblogs.com/devinzhang/archive/2012/01/19/ ...

  3. python 的基础学习 第九天 文件的操作

    1,文件操作 参数:1,文件路径  2,编码方式,3,执行动作(打开方式),只读,只写,,读写,追加和读写. 1  打开文件,得到文件句柄并赋值给一个变量.2. 通过句柄对文件进行操作.3. 关闭文件 ...

  4. bind,unbind,one

    刚开始我们先看一下它的定义: .bind( eventType [, eventData], handler(eventObject)) .Bind()方法的主要功能是在向它绑定的对象上面提供一些事件 ...

  5. bae64编码

    data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAEAAAAkCAYAAABIdFAMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJb ...

  6. day 12 - 1 装饰器进阶

    装饰器进阶 装饰器的简单回顾 装饰器开发原则:开放封闭原则装饰器的作用:在不改变原函数的调用方式的情况下,在函数的前后添加功能装饰器的本质:闭包函数 装饰器的模式 def wrapper(func): ...

  7. hibernate多表操作

    一.表之间的关系 1.一对一 2.一对多 3.多对多 二.表之间关系建表原则 1.一对多:在多的一方创建一个外键,指向一的一方的主键 2.多对多:创建一个中间表,中间表至少有两个字段,分别作为外键指向 ...

  8. 传统javaweb 改成 Maven项目

    1. 项目右键-- Configure --Convert to Maven Project 后可以生成maven结构,多了红色框的    <project xmlns="http:/ ...

  9. JDK中Concurrent包介绍及使用(包含atomic包/lock包/并发容器/执行器)

    Java Concurrent并发包概括  https://blog.csdn.net/u012232736/article/details/79919450 Java中的Atomic包使用指南   ...

  10. 音乐app各部分笔记(一)

    7-11 播放器播放时间获取和更新 1.audio 有一个 ontimeupdate事件 播放过程中 随时触发 vue里面就是  @timeupdate   事件中有默认参数 e  通过e.targe ...