- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 Symfony2 与 Doctrine2(最新版本)一起使用,并定义了此关系:
/**
* @ORM\OneToMany(targetEntity="Field", mappedBy="event", fetch="EAGER")
* @ORM\OrderBy({"name" = "ASC"})
*/
protected $fields;
关系的另一端定义为:
/**
* @ORM\ManyToOne(targetEntity="Event", inversedBy="fields", fetch="EAGER")
* @ORM\JoinColumn(nullable=false, onDelete="CASCADE")
*/
protected $event;
执行“fetchOnyById”时,Doctrine 运行 2 个查询。 1 获取对象本身,1 获取相关字段。我希望这是一个联接,但事实并非如此。
在 Controller 中完成后,我将对象传递给 twig。在那里,我再次检索字段作为对象的属性。这会导致运行另一个查询来再次检索字段。
显然我做错了什么,因为我预计只运行 1 个查询,而实际运行了 3 个查询。
最佳答案
我相信发生这种情况的原因是因为您正在获取实体,而不是特定的查询。 Doctrine 的想法是,您正在获取对象,而不是与数据库交互,而是与对象资源交互,就好像它们都像存储的实体一样关联/引用。如果您需要像您所描述的那样的查询,那么最好使用 DQL,但此时您不会获取创建的实体,而是会获得自定义结果。
我希望这是有道理的。
基本上,您使用的默认关联是获取关联对象而不是联接查询。
关于symfony - Doctrine2 急切加载运行多个查询而不是 1 个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18159333/
我有一个案例,在大多数情况下,对象之间的关系是这样的,因此在关系上预先配置一个渴望(加入)的负载是有意义的。但是现在我遇到了一种情况,我真的不想完成急切的加载。 我是否应该从关系中删除连接负载并将所有
在我的 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给出了一些提示,但不是很令人满意。 最佳答案
我是一名优秀的程序员,十分优秀!