Laravel 中多个表之间不同的关联怎么用 with 实现?

今天在代码重构的时候,看到这么一个数据查询。自己看了文档去试了一下。没有结果,不知道该怎么实现。

Laravel 中多个表之间不同的关联怎么用 with 实现?

这个是sku一个表对应的两个表,另外两个表又对应其他的表。
这个是需要用laravel重构的数据库逻辑。怎么才能实现这样的逻辑?使用with渴求式加载。希望各位能够指点一下。

Reality Change Me
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

建议你先把这几个表,相互关联的关系,在模型中全部定义好,,,之后,,,应该就比较清晰了,with 是可以嵌套的,比如 Order::with(['user', 'user.address', 'category', 'category.parent'])

1年前 评论
忽而今夏 (楼主) 1年前
讨论数量: 7
1年前 评论
忽而今夏 (作者) (楼主) 1年前

Sku 关联 SizeStyleSizeStyle 各自关联 Value

Sku::with(['size.value', 'style.value'])
1年前 评论

@yanthink 我写了这个语法,好像是语法没有写对。在sku的模型里不是只能关联size和value吗。sku表和那两个item表没有关联。 sku关联的 size 和 style 。 size关联item_wize,style关联item_style。

1年前 评论
yanthink 1年前
忽而今夏 (作者) (楼主) 1年前

@yanthink 我又重新写了逻辑,帮忙看下是否正确

在Repository中是这样调用的
file

sku模型中

file

这是对应的itemSizeValue模型

file

这是对应的itenStyleValue模型

file

1年前 评论
小猪蹄子 1年前
忽而今夏 (作者) (楼主) 1年前

建议你先把这几个表,相互关联的关系,在模型中全部定义好,,,之后,,,应该就比较清晰了,with 是可以嵌套的,比如 Order::with(['user', 'user.address', 'category', 'category.parent'])

1年前 评论
忽而今夏 (楼主) 1年前

Order::with(['price', 'user'=>function($query){
// user 模型中定义的关联
$query->with('user_info');
}])
实际是可以无限嵌套的,但是要注意,关联如果没有数据的情况 ,其实还是建议原生写,或DB

1年前 评论
忽而今夏 (楼主) 1年前

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