gpt4 book ai didi

java - Hibernate中如何连接多个表?

转载 作者:行者123 更新时间:2023-11-29 11:06:18 25 4
gpt4 key购买 nike

我有 4 个表 CustomerEntity、CustomerMaster、Request 和 UserMaster
并具有以下表格结构,

CustomerEntity  (id,address,branch,branch_id,city,entity_status,request_id,user_master_id)
CustomerMaster (id,customer_name,customer_type)
UserMaster(id,customer_master_id,employee_id,unique_id,employee_id)
Request(id,customer_master_id,parent_request_id,request_status,user_master_id)

当我像这样从 Hibernate 发出查询时

sb.append("select c from CustomerEntity c, Request r ") 

它为我提供了我需要的正确数据,但现在有一种情况我需要捕获 UserMaster id 以及 CustomerMaster id 值,这只能通过将 UserMaster 和 CustomerMaster 表与现有表连接来获取查询,但我不确定从哪里获得所有投影数据,如上面的查询所示,我正在获取“c”上的数据,但在新查询中,我希望获得加入所有这 4 个查询后执行的查询中的所有值表。

我正在使用以下查询:

sb.append("select * from  (CustomerEntity as c join Request as r
on r.id = c.request_id)
left join CustomerMaster as c1 on r.customer_master_id = c1.id
left join UserMaster as u
on r.customer_master_id = u.customer_master_id");

在 Hibernate 中是这样的,但似乎不起作用。

最佳答案

可以在 hibernate (JPA) 中连接任意数量的表。数据如何返回取决于您的业务需求。

在您的示例中,您似乎正在利用 StringBuilder/StringBuffer 创建 native SQL 查询,对吧?那是不需要的。在大多数情况下没有帮助。

通常,hibernate 用于返回映射实体,换句话说,代表数据库表数据的 Java 对象。然后,您可以在当前持久性上下文中甚至在分离状态下使用该对象的访问器和修改器(getter 和 setter)。

使用 hibernate 映射,您可以定义关系,允许您通过 Java 方法调用浏览图形来访问所有分配的对象。

也许看看here .

但这假设您使用 ORM 层的功能来访问数据,这意味着在 Session/EntityManager 对象上调用实体查询(访问方法)、HQL/JPQL 查询或使用 Criteria API。

Thisthis应该为您提供更多信息。

想象一下,您将有一个映射,它完全足以编写 HQL 查询,例如: SELECT c FROM CustomerEntity AS c这将返回一个实体。通过它的访问器,您可以浏览图表。

也可以在 HQL 中编写连接,在这种情况下,您只需告诉应该连接哪些实体,例如 SELECT c FROM CustomerEntity AS c JOIN c.request AS r ...您可以省略 ON常规情况下的条款。 Hibernate 通过映射知道实体是如何连接的。

当然,在获取适当数量的数据(急切与懒惰)和(单向与双向)方面,您的映射应该经过深思熟虑。在某些情况下,编写适合您的用例的查询甚至比通过 Java 方法导航更好,以避免性能损失,但这是您必须根据数据结构和数据大小来决定的事情。

最后但并非最不重要的一点是,您还可以使用 native SQL queries如果您需要它,但是您必须自己注意将其映射到 Java 对象。

关于java - Hibernate中如何连接多个表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41344400/

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