我找不到延迟加载的行为,如果我在JPA中有一个注释为延迟加载的“一对多”关系,当我在代码中调用来自父对象的"getChildren()“方法时会发生什么?
a) EclipseLink加载该父进程的所有子进程
b) EclipseLink一次加载一个父进程
如果响应是"a“,这是否意味着对于像数千或数百万条记录这样的大型数据集,我不应该使用”一对多“模型并实现自己的服务器端分页模型?
谢谢。
发布于 2011-01-18 21:49:47
A) -当你访问一个OneToMany时,所有的孩子都会被加载。
如果您的OneToMany太大而无法加载,则不要映射它。改为查询它。您可以在查询中设置firstResult/maxResults。
@BatchSize在OneToMany上不会有帮助。
发布于 2011-01-18 09:53:01
在JPA中,目前没有指定批处理大小的方法。所以实际上你的问题的答案是(c),这取决于实现来定义你的OneToMany集合是什么。它很可能是一个大于1的数字,但没有指定。
如果您使用的是Hibernate,则可以使用@BatchSize注释来指定要加载的数量。
如果您正在进行分页,那么您需要处理的问题之一就是集合的起点。因此,如果您每页显示50个项目,而您的用户位于第13页(共50个项目),则您希望显示集合中的项目601 - 650。即使使用JPA延迟加载,您也无法在集合中给它一个您想要的位置。因此,您可能需要自己的分页方案,使用具有指定起始位置和最大结果数的Query。
https://stackoverflow.com/questions/4719696
复制相似问题