指定lazy = "true"
和使用有fetch = "select" or "join"
什么区别 ?哪一个比另一个更好?
问候贾恩德拉
假设我们有这样的实体:
@Entity
@Table
public class Parent {
@Id
private Long id;
@OneToMany(mappedBy="parent", fetch = FetchType.EAGER)
@Fetch(FetchMode.JOIN)
private List<Child> child;
//getter setters
}
@Entity
@Table
public class Child {
@Id
private Long id;
@ManyToOne(fetch = FetchType.LAZY)
private Parent parent;
//getter setter
}
在上面的示例中,获取Parent
实体时,hibernate将自动child
使用join急切地加载所有实体。另一方面,当您提取时Child
,Parent
除非您在代码中显式调用实体,否则不会选择实体child.getParent()
。
FetchType(Lazy / Eager)告诉我们,当代码中有调用时,我们是希望实体加载还是延迟加载。
FetchMode(Select / Join)告诉我们是要向我们的实体加载其他选择还是在一个查询中使用join或subselect加载。
问题内容: 我是和的新手。 和 之间有什么区别? 问题答案: 有时你有两个实体,并且它们之间存在关系。例如,你可能有一个名为的实体,另一个实体名为,而一所大学可能有很多学生: University实体可能具有一些基本属性,例如id,名称,地址等,还有一个名为students的集合属性,该属性返回给定大学的学生列表: 一所大学有很多学生 现在,当你从数据库加载大学时,JPA会为你加载其ID,名称和地
问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:
问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。
问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然
问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra