簡體   English   中英

在沒有實體的文件中休眠本機查詢

[英]Hibernate native queries in a file with no Entity

我的第一個選擇是將一些@NamedNativeQueries放在@NamedNativeQueries數據傳輸對象(PO​​JO,如果我使用它們可以是記錄)的文件中。 但是 DTO 不是實體,因此 Hibernate 不會查看文件並且找不到查詢。 [如果您想知道,我在@ConstructorResult中使用@QueryResultSetMapping來創建對象。] 我可以使用@Entity將它們放在不同的文件中,但語義是錯誤的。

有什么神奇的方法可以讓 Hibernate 查看一個文件,否則它會忽略嗎?

您可以向會話工廠添加額外的映射資源。

例如使用 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>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM