hibernate - 带 hibernate 的 Spring Boot,我无法去掉带下划线的表名

标签 hibernate jpa spring-boot

我已经尝试了到目前为止发现的 application.properties 中的所有替代方案(见下文),但我的应用程序仍然使用“_”而不是我设置的驼峰式大小写创建表。

任何建议都将受到高度赞赏。

1 
spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.cfg.DefaultNamingStrategy

output
DefaultNamingStrategy cannot be cast to org.hibernate.boot.model.naming.ImplicitNamingStrategy

2
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.cfg.DefaultNamingStrategy
output
org.hibernate.cfg.DefaultNamingStrategy cannot be cast to org.hibernate.boot.model.naming.PhysicalNamingStrategy

3
spring.jpa.hibernate.naming.strategy=org.hibernate.cfg.DefaultNamingStrategy
output
org.hibernate.SQL                        : drop table tipo_dominio if exists
NOTE: no error but I didn't get the table name without "_"

4
spring.jpa.hibernate.naming.strategy=org.hibernate.cfg.EJB3NamingStrategy
output
EJB3NamingStrategy cannot be cast to org.hibernate.boot.model.naming.PhysicalNamingStrategy

我的实体

import java.io.Serializable;
import java.util.Date;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;




@Entity(name="TipoDominio")
@Table(name="TipoDominio")
public class TipoDominio implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue
    private Long id;

pom

    <properties>
        <main.basedir>${basedir}/../..</main.basedir>

        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>


        <!-- Compile -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
            <version>1.5.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>1.5.1.RELEASE</version>
        </dependency>
        <!-- Runtime -->
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>runtime</scope>
            <version>1.4.193</version>
        </dependency>
        <!-- Test -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <version>1.5.1.RELEASE</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

主要内容

@SpringBootApplication
public class App {
    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}

*** 已编辑 我试过了

@SpringBootApplication(exclude={HibernateJpaAutoConfiguration.class

也没有成功

最佳答案

对于 SpringBoot 1.5.x,hibernate 版本是“5.x”。这意味着不带下划线的表的命名策略类已更改。这应该适用于您所拥有的。

spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

请注意,配置属性名称以及类都发生了更改。

关于hibernate - 带 hibernate 的 Spring Boot,我无法去掉带下划线的表名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42076121/

相关文章:

java - 与数据库无关的查询,根据主键获取行号

java - SolrCrud存储库: use inheritance

java - 如何在持久化之前根据 transient 属性计算持久化属性?

java - 使用 Spring Boot 和 Hibernate 强制执行外键约束的替代方法

java - Hibernate的@DiscriminatorColumn映射可以吗

json - 如何处理多态类型和 JSON 的双向引用?

spring - 将查询参数映射到 @ModelAttribute 不尊重 @JsonProperty 名称

java - 如何在 Spring Boot Restful 中更改大量数据(更新多个数据)

java - "DataBase encryption in Hibernate"返回 'encryptedBody' 中的未知列 'field list'

java.lang.NoClassDefFoundError : Could not initialize class org. springframework.beans.CachedIntrospectionResults 问题