- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经阅读了几篇关于为什么预加载使用多个查询而不是加入 here 的帖子, here , 和 here .但是,我认为有必要使用连接而不是急切加载。我将如何构造查询,以便我可以访问子对象,就好像它是一个通常急切加载的对象一样?
示例:获取住在某条街道上的人,并同时加载该地址。我不想加载这个人的所有地址,以防他住在很多地方;只是匹配查询的地方。使用预加载和 whereHas 我必须复制查询,而且查询并不总是这么简单:
People::with(['address', function($query) use ($street_name){
return $query->where('street_name', $street_name);
}])->whereHas('address', function($query) use ($street_name){
return $query->where('street_name', $street_name);
})->get();
可能是
People::query()->join('address', function($join){
$join->on(...)
})->where('street_name', $street_name);
问题是我不能使用这个:
$person->address
有没有办法获取连接并对其进行处理(使用选择?),使其看起来像是急切加载的?
最佳答案
您可以执行以下操作:
People::join('addresses', 'addresses.people_id', '=', 'people.id')
->selectRaw('people.*')
->where('street_name', $street_name)
->with('addresses')
->get();
这使用了连接和预先加载。
仅通过连接,您可以访问以下内容:
$person->street_address
关于laravel - 我可以使用连接伪造 laravel 急切加载吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41771142/
我有一个案例,在大多数情况下,对象之间的关系是这样的,因此在关系上预先配置一个渴望(加入)的负载是有意义的。但是现在我遇到了一种情况,我真的不想完成急切的加载。 我是否应该从关系中删除连接负载并将所有
在我的 Grails 项目中,我有以下类: class A { static hasMany = [cs:C] } class B { static hasMany = [cs:C]
想象一下以下简化的 DI 模型: @ApplicationScoped public class A { private B b; @Inject public A(B b)
我使用 MapLoader 将数据从数据存储初始加载到 Hazelcast (InitialLoadMode = EAGER)。我需要从一个物化 View 中加载这些数据,该 View 是为了在加载过
我使用 Hibernate Envers 4.3.10.Final。我有以下两个 JPA 类: public class Factory { private int factoryID;
EJB 似乎被延迟加载 - 每当访问时。 但是,我想急切地初始化它们 - 即每当容器启动时。这是如何实现的(尤其是在 JBoss 中) This topic给出了一些提示,但不是很令人满意。 最佳答案
我是一名优秀的程序员,十分优秀!