- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我看过各种帖子,描述 JPA EntityGraph 允许在运行时选择图表。我不太清楚这指的是什么。
出于善意和尊重,我想引用这篇有用的文章:https://www.baeldung.com/jpa-entity-graph 。 (大多数 JPA 用户可能已经经历过它。)
文章引用 -
EntityGraph allows grouping the related persistence fields which wewant to retrieve and lets us choose the graph type at runtime.
并在结论部分再次巩固了上述陈述。
In this article, we've explored using the JPA Entity Graph todynamically fetch an Entity and its associations.
The decision is made at runtime in which we choose to load or not therelated association.
正如我们在文章 (5.1) 中看到的 - EntityGraph 使用注释定义如下 -
5.1。使用注释定义实体图
@NamedEntityGraph(
name = "post-entity-graph",
attributeNodes = {
@NamedAttributeNode("subject"),
@NamedAttributeNode("user"),
@NamedAttributeNode("comments"),
}
)
@Entity
public class Post {
@OneToMany(mappedBy = "post")
private List<Comment> comments = new ArrayList<>();
//...
}
@NameEntityGraph 注释是在编译时定义的,我在这里没有看到任何运行时或动态的内容。
但在 5.2 中 - 实体图是使用 API 或以编程方式定义的 -
5.2。使用 JPA API 定义实体图
EntityGraph<Post> entityGraph = entityManager.createEntityGraph(Post.class);
entityGraph.addAttributeNodes("subject");
entityGraph.addAttributeNodes("user");
在 5.2 方法中,我看到可以使用某种逻辑动态选择节点。这种方法就是所谓的“动态获取”和“基于运行时”。或者我错过了什么,我还有更多需要理解的吗?
进一步采用6 中给出的方法。使用实体图
例如:
EntityGraph entityGraph = entityManager.getEntityGraph("post-entity-graph");
Map<String, Object> properties = new HashMap<>();
properties.put("javax.persistence.fetchgraph", entityGraph);
Post post = entityManager.find(Post.class, id, properties);
都是编程性的,因此可以在运行时更改,即它们可以说是动态的。
但是上面的文章中遗漏了一种方法,但在这里提到了 - https://www.baeldung.com/spring-data-jpa-named-entity-graphs如下所示,似乎不符合动态标准。
public interface ItemRepository extends JpaRepository<Item, Long> {
@EntityGraph(value = "Item.characteristics")
Item findByName(String name);
}
动态方法是否仅指 5.2 风格,或者甚至也暗示 5.1 风格。
最佳答案
您不能将动态实体图与 spring-data 一起使用,因为 JpaRepository
没有方法来传递实体图,例如
Optional<T> findById(ID id, EntityGraph entityGraph);
使用自定义 JPA 存储库
您可以通过创建自定义存储库并通过 EntityManager
使用实体图来使用原始 JPA。
使用 spring-data-jpa-entity-graph
使用库 spring-data-jpa-entity-graph 有一种更方便的方法.
它允许将 findById()
或 findByName()
等 JPA 存储库方法与动态实体图一起使用。
我更喜欢将它与这个辅助类一起使用
public abstract class EntityGraphBuilder<T> {
private List<String> result = new ArrayList<>();
protected T self;
public T add(String path) {
result.add(path);
return self;
}
public DynamicEntityGraph build() {
return new DynamicEntityGraph(EntityGraphType.FETCH, result);
}
}
每个实体都有自己的GraphBuilder
@Entity
public class OrderEntity {
@Id
private Long id;
@Column
private name;
@ManyToOne(fetch = FetchType.LAZY)
private OrderRequestEntity orderRequest;
@ManyToOne(fetch = FetchType.LAZY)
private ProviderEntity provider;
public static GraphBuilder graph() {
return new GraphBuilder();
}
public static class GraphBuilder extends EntityGraphBuilder<GraphBuilder> {
private GraphBuilder() {
self = this;
}
public GraphBuilder orderRequest() {
return add("orderRequest");
}
public GraphBuilder provider() {
return add("provider");
}
}
}
存储库使用 spring-data-jpa-entity-graph
库中的 EntityGraphJpaRepository
@Repository
public interface OrdersRepository extends EntityGraphJpaRepository<OrderEntity, Long> {
OrderEntity findByName(String name, EntityGraph entityGraph);
}
您也可以将 findByName()
等派生查询方法与动态实体图结合使用。
使用findById()
方法的示例,相同的方法可以应用于findByName()
OrdersRepository ordersRepository;
Long orderId = 1L;
OrderEntity order = ordersRepository.findById(
orderId,
OrderEntity.graph().orderRequest().provider().build()
).orElseThrow(
() -> new ServiceException("Can't find orderId=" + orderId)
);
关于java - JPA EntityGraph 如何允许在运行时选择实体图?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71175593/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!