在没有实体的文件中进行 Hibernate 本机查询

问题描述 投票:0回答:2

我首先选择放置一些

@NamedNativeQueries
的位置是定义数据传输对象(POJO,如果我使用它们的话,可能是一条记录)的文件。但 DTO 不是一个实体,因此 Hibernate 不会查看该文件,也不会找到查询。 [如果您想知道,我在
@ConstructorResult
中使用
@QueryResultSetMapping
来创建对象。] 我可以使用
@Entity
将它们放在不同的文件中,但语义是错误的。

有什么神奇的方法可以让 Hibernate 查看它会忽略的文件吗?

java hibernate annotations annotation-processing
2个回答
1
投票

您可以向会话工厂添加额外的映射资源。

例如使用 Spring Boot:

spring.jpa.mapping-resources=hibernate/MyMapping.hbm.xml,hibernate/MyMapping2.hbm.xml

或没有 Spring Boot(来自 https://mkyong.com/hibernate/how-to-add-hibernate-xml-mapping-file-hbm-xml-programmatically/):

SessionFactory sessionFactory = new Configuration()
   .addResource("hibernate/MyMapping.hbm.xml")
   .buildSessionFactory();

然后在添加的文件中(例如

hibernate/MyMapping.hbm.xml
),您可以插入命名查询:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <sql-query name="test">
        select count(*) from SYSIBM.SYSDUMMY1
    </sql-query>
</hibernate-mapping>


0
投票

我不确定所需的 Hibernate 最低版本,但将以下行添加到 persistence.xml 文件效果很好。

<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
    <class>a.b.c.File1</class>
    <class>a.b.c.File2</class>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
<--! etc -->
© www.soinside.com 2019 - 2024. All rights reserved.