gpt4 book ai didi

java - 实体图不起作用 - 返回所有实体

转载 作者:行者123 更新时间:2023-12-02 09:06:06 25 4
gpt4 key购买 nike

我正在 springdata jpa 的简单场景中尝试 EntityGraph:

这个想法只是获取一个带有 id 字段的实体,并省略另一个名为 name 的字段。

这是要检索的实体:

Entity
@NamedEntityGraph(name = "Region.id",
attributeNodes = @NamedAttributeNode("id"))
public class Region {
@Id
public String id;

public String name;



public String getId() {
return id;
}

public void setId(String id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}
}

存储库:

public interface RegionRepository extends JpaRepository<Region, String>{

@EntityGraph(value = "Region.id")
Region findByRegionId(String name);

}

和服务:

@Service
public class RegionService {

@Autowired
private RegionRepository regionRepository;


public Region getRegion(String regionId) {
Region region = regionRepository.findByRegionId(regionId);
return region;
}
}

如前所述,检索整个区域。

我尝试了另一种方法,使用了更多的代码。

添加了一个界面:

public interface RegionRepositoryCustom {
Region findByRegionId(String name);
}

并用它来添加一个 impl 类:


public class RegionRepositoryImpl implements RegionRepositoryCustom{
@PersistenceContext
private EntityManager em;

@Override
@Transactional
public Region findByRegionId(String id) {

EntityGraph<Region> entityGraph = (EntityGraph<Region>) em.getEntityGraph("Region.id");

Region region = em.createQuery("select r from Region r where r.id = :id", Region.class)
.setParameter("id", id)
.setHint("javax.persistence.fetchgraph", entityGraph)
.getSingleResult();

return region;
}

}

并尝试了这个变体:


public class RegionRepositoryImpl implements RegionRepositoryCustom{
@PersistenceContext
private EntityManager em;

@Override
@Transactional
public Region findByRegionId(String id) {

//EntityGraph<Region> entityGraph = em.createEntityGraph(Region.class);
//entityGraph.addAttributeNodes("id");

EntityGraph<Region> entityGraph = (EntityGraph<Region>) em.getEntityGraph("Region.id");

Map<String, Object> properties = new HashMap<>();
properties.put("javax.persistence.fetchgraph", entityGraph);

Region region = em.find(Region.class, id, properties);


return region;
}

}

还使用 H2 和 application.properties 设置:

spring.jpa.show-sql=true

spring.jpa.properties.hibernate.format_sql=true



spring.datasource.url=jdbc:h2:mem:AZ;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE;AUTO_RECONNECT=TRUE
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver

spring.jpa.database-platform=org.hibernate.dialect.H2Dialect

spring.jpa.hibernate.ddl-auto=create-drop

spring.jackson.serialization.FAIL_ON_EMPTY_BEANS=false

这是在 ide 控制台中看到的 SQL 模板:

Hibernate: 
select
region0_.id as id1_0_,
region0_.name as name2_0_
from
region region0_
where
region0_.id=?

一切都不起作用...

我错过了什么?

最佳答案

EntityGraph 旨在急切地获取两个实体之间的关系,以便仅在需要时才获取它。这样做是因为连接表的性能成本可能会很高,并且只有在特别需要时才应该这样做。

如果您确实不想要该名称,可以将其从实体区域中删除,这样就不会再获取该名称。

有关实体图的更多详细信息:https://thoughts-on-java.org/jpa-21-entity-graph-part-1-named-entity/

关于java - 实体图不起作用 - 返回所有实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59881275/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com