JPA 大写表名

Posted

技术标签:

【中文标题】JPA 大写表名【英文标题】:JPA Uppercase table names 【发布时间】:2016-07-21 02:13:37 【问题描述】:

我在 Postgresql 中有一个表:

CREATE TABLE "UTILISATEUR"(
 
 "IdUtilisateur" serial NOT NULL,
 "Nom" character varying(50),
 "Prenom" character varying(50),
 "Profil" character varying(50),
 "Pseudo" character varying(20),
 "IdSite" integer DEFAULT 0,
 "Password" character varying(1024),
  id_role integer,
  )

我正在这个表上尝试 Map 所以我使用了@Table JPA 注释(见下文)。这是我的application.propreties

spring.datasource.url = jdbc:postgresql://localhost/baseecu
spring.datasource.username = postgres
spring.datasource.password =root
spring.datasource.driverClassName=org.postgresql.Driver
spring.jpa.database = mysql 
spring.jpa.show-sql = true
spring.jpa.hibernate.ddl-auto=update 
spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5InnoDBDialect

最后这是我的实体类:

@Entity
@Table(name="UTILISATEUR")
public class Utilisateur   
@Id
@GeneratedValue(strategy=GenerationType.AUTO) 
@Column(name="IdUtilisateur")
public Long id ;
public String Nom ; 
public String Prenom ; 
public String Profil ; 
public String Pseudo ; 


public String Password ;
@ManyToOne
@JoinColumn(name="id_role")
public Role role ;
public Long getId() 
    return id;

如果我有这样的@Table(name="UTILISATEUR") 我会从 PostgreSQL 得到消息

ERREUR: la relation « utilisateur » n'existe pas 

当我试图逃避引用 @Table(name="\"UTILISATEUR\"")

ERROR: syntax error at or near "`"

我尝试了这个问题的回答,但它不起作用

Spring boot JPA insert in TABLE with uppercase name with Hibernate

更新

我一直在搜索有关改进命名策略的信息,这似乎是 spring boot 中的一个问题,而不是我使用了 EJB3NamingStrategy 和 DefaultNamingStrategy 它不起作用当 Hibernate 执行 SQL 时结果非常令人困惑,这很有趣:

Hibernate: select utilisateu0_.IdUtilisateur as IdUtilis1_2_, utilisateu0_.Nom as Nom2_2_, utilisateu0_.Password as Password3_2_, utilisateu0_.Prenom as Prenom4_2_, utilisateu0_.Profil as Profil5_2_, utilisateu0_.Pseudo as Pseudo6_2_, utilisateu0_.id_role as id_role7_2_ from UTILISATEUR utilisateu0_ 

就像它知道表名是大写但不想映射或者我不知道这是使用的结果

spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.DefaultNamingStrategy
or 
spring.jpa.hibernate.naming_strategy = org.hibernate.cfg.DefaultNamingStrategy

还有 EJB3NamingStrategy

这也是我这样使用注解的结果

@Table(name="UTILISATEUR")  

我也试过这样

@Table(name="\"UTILISATEUR\"")

我得到了问题

ERROR: syntax error at or near "`"

Hibernate: select utilisateu0_.IdUtilisateur as IdUtilis1_2_, utilisateu0_.Nom as Nom2_2_, utilisateu0_.Password as Password3_2_, utilisateu0_.Prenom as Prenom4_2_, utilisateu0_.Profil as Profil5_2_, utilisateu0_.Pseudo as Pseudo6_2_, utilisateu0_.id_role as id_role7_2_ from `UTILISATEUR` utilisateu0_ 

最后这是我的pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.xx.MDValidation</groupId>
<artifactId>xx.MDValidation</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>

<name>xx.MDValidation</name>
<description>Projet Validation xx</description>

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.2.RELEASE</version>
</parent>
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <java.version>1.8</java.version>
<hibernate.version>4.2.21.Final</hibernate.version>
<commons-dbcp.version>1.2.2</commons-dbcp.version>
</properties>

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

    
        <dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.1-901.jdbc4</version>
</dependency>
<dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>

    
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </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-jooq</artifactId>
    </dependency>
    <dependency>
        <groupId>bsf</groupId>
        <artifactId>bsf</artifactId>
        <version>2.4.0</version>
    </dependency>
    </dependencies>


<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

【问题讨论】:

最好的方法是永远不要使用带引号的标识符——它们比它们更值得麻烦。 我知道,但是我无法触及数据库结构:/这是他们拥有数据库并且您将要使用它的那些项目 在我使用的 JPA 实现(DataNucleus)中,我可以简单地将持久性属性设置为“小写”或“大写”,它会对指定的内容进行必要的更改,并且一切正常。也许您选择的实现有类似的东西? 在我看来,你可以做的是实现一个custom naming strategy 将实体名称转换为它们对应的表名称。 如果您使用的是 postgres,那么您为什么要使用 Mysql 方言?! 【参考方案1】:

您可以使用下一行来配置您的应用程序,具体取决于数据库:

MySql

spring.jpa.hibernate.naming_strategy = org.hibernate.cfg.DefaultNamingStrategy

Postgres

spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect

甲骨文

spring.jpa.database-platform=org.hibernate.dialect.Oracle10gDialect

【讨论】:

【参考方案2】:

我遇到了同样的问题,我像这样在实体声明中引用 (`) 我的表名 “`UTILISATEUR`”。 @Table(name = "`UTILISATEUR`")

` 使用带有方言的 postgresql 11:org.hibernate.dialect.PostgreSQL95Dialect 它在数据库上生成了一个大写的表名。

【讨论】:

这个答案不是很清楚。请修改您的问题,以便提供更多背景信息。【参考方案3】:

可能是因为您使用的是 MYSQL5DIALECT,所以使用了 Postgres 方言,就像这样发布它,并且对于改进的命名策略,使用 EJB3 之类的 Spring boot JPA insert in TABLE with uppercase name with Hibernate

spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect

希望对你有用

【讨论】:

对于使用较新版本的人:PostgreSQLDialect 已弃用:使用 PostgreSQL82Dialect 代替 doc:docs.jboss.org/hibernate/orm/5.0/javadocs/org/hibernate/dialect/…【参考方案4】:

我在 postgres 8.4 和 hibernate 5.0.3 中复制了您的 UTILISATEUR 表(已删除角色)。

使用显式表名和列名注释可以按预期工作:

@Entity(name="\"UTILISATEUR\"")
public class Utilisateur 

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO) 
    @Column(name="\"IdUtilisateur\"")
    private Long id ;

    @Column(name="\"Nom\"")
    private String Nom ; 
    @Column(name="\"Prenom\"")
    private String Prenom ; 
    @Column(name="\"Profil\"")
    private String Profil ; 
    @Column(name="\"Pseudo\"")
    private String Pseudo ; 

    @Column(name="\"Password\"")
    private String Password ;

    ... getter / setters


【讨论】:

org.hibernate.QueryException: unexpected char: '"' [select generatedAlias0 from "UTILISATEUR" as generatedAlias0] 你可以尝试对你的数据库运行这个吗? peter.risko.hu/java_incubator/… 这是另一个我不能使用的结构 好吧,如果我是你,我会尝试缩小问题的范围。我将创建一个简化的 Utilisateur 表并专注于区分大小写的表名/列名。我的第一步是确保可以毫无错误地处理简化的情况。如果这有效,那么我将开始修改有效的解决方案——尽管是简化的——解决方案,使其更类似于实际系统(更多列、表连接、查询等)。我附上的代码可能是您朝这个方向迈出的第一步。 感谢您长期以来所做的一切冒险

以上是关于JPA 大写表名的主要内容,如果未能解决你的问题,请参考以下文章

spring boot + JPA + MySql + Entity 表生成大写

Spring Boot + JPA(hibernate 5) 开发时,数据库表名大小写问题

MySQL查询

MySQL + Windows 和小写表名

MySQL--4 查询

JPA 表名大小写问题