spring - 如何在 Spring Boot 应用程序中设置 Hibernate bulk_id_strategy?

标签 spring hibernate jpa spring-boot embedded-tomcat-8

Hibernate 正在为 TABLE_PER_CLASS 继承生成临时表,但是 prod。 oracle 用户没有那些创建表权限,因此这种方法不是我们项目的选择。

据说 Hibernate Version 5.2.8 解决了这个问题。
我们相应地更新了 pom.xml 以覆盖默认的 starter hibernate 版本设置。

仍然我们对以下属性没有任何运气。

 <property name="hibernate.hql.bulk_id_strategy"
 value="org.hibernate.hql.spi.id.inline.InlineIdsInClauseBulkIdStrategy"
   />

APPLICATION PROPERTIES 也更新如下

**
spring.datasource.driver-class-name=oracle.jdbc.OracleDriver
spring.datasource.url=jdbc:oracle:thin:@192.168.1. :1521:
spring.datasource.username= 
spring.datasource.password= 
spring.jpa.hibernate.ddl-auto=none
spring.jpa.database-platform=org.hibernate.dialect.Oracle10gDialect
spring.jpa.show-sql=true
spring.jpa.hibernate.hql.bulk_id_strategy=org.hibernate.hql.spi.id.inline.InlineIdsInClauseBulkIdStrategy

**

此设置在 Spring Boot 应用程序中的正确位置在哪里?

容器仍在测试环境中生成临时表。服务器启动。

亲切的问候

pom.xml 如下

http://maven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0
<groupId>x.xx.ortakonline</groupId>
<artifactId>PolsanOrtakOnlineServer</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.0.RELEASE</version>

</parent>


<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <java.version>1.8</java.version>
    <jjwt.version>0.7.0</jjwt.version>
      <hibernate.version>5.2.8.Final</hibernate.version>
</properties>


<dependencies>
    <dependency>

        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>

    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>


    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

    <dependency>
        <groupId>com.oracle</groupId>
        <artifactId>ojdbc14</artifactId>
        <version>10.2.0.4.0</version>
    </dependency>


    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope> test </scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>io.jsonwebtoken</groupId>
        <artifactId>jjwt</artifactId>
        <version>0.7.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.mobile</groupId>
        <artifactId>spring-mobile-device</artifactId>
    </dependency>


    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-jpamodelgen</artifactId>
    </dependency>
</dependencies>

最佳答案

In addition all properties in spring.jpa.properties.* are passed through as normal JPA properties (with the prefix stripped) when the local EntityManagerFactory is created.



这来自 Spring Boot 引用指南中的 the JPA section,简而言之,它解释了如何传递其他提供者特定的属性。

将以下内容添加到您的 application.properties 应该可以解决问题
spring.jpa.properties.hibernate.hql.bulk_id_strategy=org.hibernate.hql.spi.id.inline.InlineIdsInClauseBulkIdStrategy

关于spring - 如何在 Spring Boot 应用程序中设置 Hibernate bulk_id_strategy?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42763309/

相关文章:

java - BoneCP 支持 XA 事务吗?

mysql - 插入后从spring检索数据不起作用

java - 如何使用 JPA native 查询将 List<Object> 转换为 POJO

java - STS 中没有 Maven 的 Spring Boot 项目

Hibernate @ManyToOne-仅一个方向关系

java - 子表中未生成单向一对一映射外主键

java - 用于调用存储过程的 Spring JDBC 模板

java - Spring Boot war 部署无法在差异机器上使用相同的配置进行初始化

java - Hibernate 将实例转换为子类

java - Persistence.XML JavaEE 与 EJB 和 Intellij