0

我有 2 张桌子:

CREATE TABLE `addr1` (
  `id` int(11) DEFAULT NULL,
  `addr2` varchar(20) DEFAULT NULL
) ENGINE=InnoDB;

CREATE TABLE `address` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `address` varchar(250) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB;

的主键addr1是从地址表中设置的。我使用联合继承创建了我的实体

@Entity
@Table(name="addr1")
public class Addr1 extends Address {
    @Column(name="addr2")
    private String addr2;
    // getters and setters follows
}

@Entity
@Table(name = "address")
@Inheritance(strategy=InheritanceType.JOINED)
public class Address implements Serializable {

    @Id
    @GeneratedValue
    @Column(name = "id")
    private int id;

    @Column(name = "address", nullable = false, length = 250, insertable = true)
    private String address;
    // getters and setters follows
}

现在我在地址表中有一行 ID 为 2。我想在 addr1 表中插入一行 ID 相同 (2)。我试过

Address addr = em.getReference(Address.class, new Integer(4));
Addr1 addr1 = new Addr1(addr);
addr1.setAddr2("dsdsd");
em.persist(addr1);

但我收到一个错误

javax.persistence.PersistenceException:org.hibernate.PersistentObjectException:分离的实体传递给坚持:Addr1

请帮我。

问候, 普拉文

4

1 回答 1

0

不可能。继承意味着一种is-a关系。因此,您的实体实例可以是裸机Address,也可以是Addr1. Java 对象不能改变它的类型。您不能获取 Object 类型的对象,并要求 JVM 更改其类型并使其成为 String 类型的对象。这里也一样。

如果你需要这样做,那么你应该使用组合,而不是继承:一个地址可以一个 Addr1。因此,您应该在 Address 和 Addr1 之间有一个 OneToOne 关联,而不是继承关系。

于 2012-06-15T05:49:21.733 回答