1

JPA 规范或官方文档中是否有关于某些 JPA 实现的声明,这些声明描述了我们注释实体方法和注释实体字段时的行为?

就在几个小时前,我遇到了一个丑陋的问题:我将 JPA(通过 Hibernate,但在 java 代码中没有任何特定于 Hybernate 的东西)与 MS SQL Server 一起使用。我将所有注释都放在实体的字段上(直到今天我更喜欢这种风格)。

当我查看数据库时,我发现所有应该是外键并且应该包含一些整数(id)的表列实际上都有varbinary(255, null)类型并且包含一些东西的哈希值(我不知道那是什么,但它看起来像一个典型的MD5 哈希)。

最令人沮丧的是该应用程序运行正常。但偶尔(更新时)我得到 MS SQL 异常,指出我试图插入太长的值并且无法截断数据。

最终(作为实验)我从实体字段中删除了所有注释并将它们全部放在方法上。我重新创建了数据库,所有表都包含完美的 FK 列。这些列存储整数(ID,如 1、3、4 ...)。

那么,有人可以解释那是什么吗?

我找到了这个 SO 线程并且它被接受的答案说首选方法是将注释放在字段上。至少对于我的具体情况,我可以说这不是真的。

4

2 回答 2

0

根据经验,我做了以下事情。

  1. 我将实体详细信息放在实体类定义的顶部,例如(模式、行约束等)......

    @Entity
    @Table(name="MY_TABLE", schema = "MY_SCHEMA", uniqueConstraints = @UniqueConstraint(columnNames = "CONSTRAINT1"))
    
  2. 对于定义的字段,我没有将注释放在字段声明上,而是放在这些字段的 getter 方法上

    @Column(name = "MY_COL", table="MY_TABLE", nullable = false, length = 35)
    public String getMyCol() {
        return this.myCol;
    }
    
    public void setMyCol(String myCol) {
        this.myCol = myCol;
    }
    
于 2011-11-03T10:49:00.480 回答
0

JPA 允许对持久类的数据进行两种类型的访问。字段访问意味着它将实例变量(字段)映射到数据库中的列,而属性访问意味着使用 getter 来确定将映射到数据库的属性名称。它将使用什么访问类型取决于您将 @Id 注释放在哪里(在 id 字段或 getId() 方法上)。

于 2013-03-12T08:00:37.183 回答