如何在 spring 引导应用程序中设置休眠 bulk_id_strategy?

How to set Hibernate bulk_id_strategy in spring boot application?

Hibernate 正在为 TABLE_PER_CLASS 继承生成临时 tables,但产品。 oracle 用户没有那些 create table 权限,因此该方法不适合我们的项目。

Hibernate 版本 5.2.8 据说可以解决该问题。 我们相应地更新了 pom.xml 以覆盖默认启动器休眠版本设置。

我们仍然没有遇到以下 属性.

 <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 引导应用程序中的正确位置在哪里?

容器仍在测试环境中生成温度 tables。服务器启动。

亲切的问候

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 引导参考指南中的 the JPA section,简而言之,解释了如何传递其他提供程序特定的属性。

将以下内容添加到您的 application.properties 应该可以解决问题

spring.jpa.properties.hibernate.hql.bulk_id_strategy=org.hibernate.hql.spi.id.inline.InlineIdsInClauseBulkIdStrategy

根据上面 的建议,您应该将以下内容添加到 application.properties 文件中:

spring.jpa.properties.hibernate.hql.bulk_id_strategy=org.hibernate.hql.spi.id.inline.InlineIdsInClauseBulkIdStrategy

并将以下内容添加到 pom.xmlproperties 部分以覆盖捆绑的 hibernate-core 库。这是为了确保找到 InlineIdsInClauseBulkIdStrategy class,因为 class 仅在 Hibernate Core 5.3.1.Final 及更高版本中可用:

<properties>
        ...
        <hibernate.version>5.3.1.Final</hibernate.version>
</properties>