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

标签 java mysql hibernate join

我有 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/

相关文章:

java - 当我尝试创建值数组时出现截断错误

java - Eclipse 中的 Struts 2 给出 "requested resource not found"

mysql - 在 MySql 的滑动时间窗口内运行每个 id 的总数

mysql - 在mysql中创建事件

java - @事务被忽略

java - 在 intellij 中禁用 Cannot Resolve Method 突出显示

java - 使用 JAVA 向 LDAP 中的现有用户添加属性

mysql - 如果 mysql 列有数据,则返回 1 或 0

java - 不引用外键实体的 hibernate 外键

java - 按日期升序排序,最后为空