gpt4 book ai didi

java - 双向多对一映射

转载 作者:行者123 更新时间:2023-12-01 12:11:16 25 4
gpt4 key购买 nike

我是 JAVA 和 JPA 的新手,我用 google 搜索解决方案但没有结果。我找到了很多例子,但它们在我的场景中不起作用。我想映射下面给出的这两个表:

书架 table

CREATE TABLE "SOA2"."BOOKSHELF"  (  
"BOOKSHELF_ID" NUMBER(19,0) NOT NULL ENABLE,
"NAME_TXT" VARCHAR2(255 CHAR),
PRIMARY KEY ("BOOKSHELF_ID") USING INDEX PCTFREE 10 INITRANS 2
MAXTRANS 255 NOCOMPRESS LOGGING
TABLESPACE "SOA2" ENABLE
) SEGMENT CREATION DEFERRED PCTFREE 10 PCTUSED 40 INITRANS 1
MAXTRANS 255 NOCOMPRESS LOGGING TABLESPACE "SOA2" ;

图书表

CREATE TABLE "SOA2"."BOOK" (    
"BOOK_IX" NUMBER(19,0) NOT NULL ENABLE,
"BOOKSHELF_ID" NUMBER(19,0) NOT NULL ENABLE,
"NAME_TXT" VARCHAR2(255 CHAR),
PRIMARY KEY ("BOOK_IX", "BOOKSHELF_ID") USING INDEX PCTFREE 10 INITRANS 2
MAXTRANS 255 NOCOMPRESS LOGGING TABLESPACE "SOA2" ENABLE, CONSTRAINT "FK_RJWHY4FC"
FOREIGN KEY ("BOOKSHELF_ID")
REFERENCES "SOA2"."BOOKSHELF" ("BOOKSHELF_ID") ENABLE)
SEGMENT CREATION DEFERRED PCTFREE 10 PCTUSED 40 INITRANS 1
MAXTRANS 255 NOCOMPRESS LOGGING TABLESPACE "SOA2" ;

为了便于理解,其结构如下所示

Bookshelf TableBook Table经过所有搜索后,我使用了 Eclipse“表中的 JPA 实体”工具。它为我生成了以下类:

Bookshelf.java

@Entity
@Table(name="BOOKSHELF")
public class Bookshelf implements Serializable {
@Id
@Column(name="BOOKSHELF_ID", unique=true)
private long bookshelfId;
@Column(name="NAME_TXT")
private String nameTxt;
//bi-directional many-to-one association to Book
@OneToMany(mappedBy="bookshelf", cascade={CascadeType.ALL})
private List<Book> books;
public List<Book> getBooks() {
return this.books;
}
public void setBooks(List<Book> books) {
this.books = books;
}
//Code removed for the sake of brevity
}

Book.java

    @Entity
@Table(name="BOOK")
public class Book implements Serializable {
@EmbeddedId
private BookPK id;
@Column(name="NAME_TXT", length=255)
private String nameTxt;
//bi-directional many-to-one association to Bookshelf
@ManyToOne(cascade={CascadeType.ALL})
@JoinColumn(name="BOOKSHELF_ID", nullable=false, insertable=false, updatable=false)
private Bookshelf bookshelf;
//Code removed for the sake of brevity
}

BookPK.java

@Embeddable
public class BookPK implements Serializable {
@Column(name="BOOK_IX")
private long bookIx;
@Column(name="BOOKSHELF_ID", insertable=false, updatable=false, unique=true, nullable=false)
private long bookshelfId;
public BookPK(long bkShlfId, long bkId) {
this.bookshelfId = bkShlfId;
this.bookIx = bkId;
}
//Code removed for the sake of brevity

}

我正在测试它:Test.java

        //Physics Bookshelf
Bookshelf physicsShelf = new Bookshelf();
physicsShelf.setNameTxt("Physics");
physicsShelf.setBookshelfId(500);
//Add Books
Book book1 = new Book();
book1.setNameTxt("God and the Physics");
book1.setId(new BookPK(500, 600));

Book book2 = new Book();
book2.setNameTxt("Hyperspace");
//if I pass 500 as first param in below constructor
//Changing 500 to 501 solves the issue
book2.setId(new BookPK(500, 600)); //javax.persistence.EntityExistsException: A different object with the same identifier value was already associated with the session : [books.Book#books.BookPK@8a6d]

//Add Books into list
List<Book> bookList = new ArrayList<Book>();
bookList.add(book1);
//Error: Following error appears if I uncomment the following line
bookList.add(book2); //Caused by: java.sql.SQLIntegrityConstraintViolationException: ORA-02291: integrity constraint (SOA2.FK_RJ) violated - parent key not found
//Set Books
physicsShelf.setBooks(bookList);
EntityTransaction transaction = entitymanager.getTransaction();
transaction.begin();
entitymanager.persist(physicsShelf);
transaction.commit();

physicalsShelf 仅成功插入一本书,如果我在 bookList 中插入第二本书,则会出现 Test.java 注释中描述的错误。

请指导我

  1. 我做错了什么以及如何纠正。我真的被困住了。

  2. 有没有办法通过注释其他两个类来摆脱 BookPK.java 类。

我无法更改数据库我使用的是 Oracle 11g 和 JPA 2.1

任何帮助将不胜感激

问候

最佳答案

id 应该是唯一的,但在您的情况下,您将 book1 和 book2 的 id 设置为 Book(500,600)

book2.setId(new BookPK(500, 600)); //javax.persistence.EntityExistsException: A different object with the same identifier value was already associated with the session : [books.Book#books.BookPK@8a6d

因此,当您尝试添加 book2.setId(newBookPK(500,600)); 时,它会提示它已经存在。

尝试

book2.setId(new BookPK(500, 601));

编辑:第二个问题

我想你可以。在您的 Book 实体中尝试替换

@EmbeddedId
private BookPK id;

@Id
@Column(name="BOOK_IX")
private long bookIx;

关于java - 双向多对一映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27264709/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com