2013-02-25 52 views
0

我在BookShelf和Book之間有一對多的關係。書籍表中的ISBN編號是一個獨特的字段。現在當我嘗試插入書架(具有相同的isbn數字)的書架時,我得到一個約束衝突異常,並且書籍表中的記錄未插入。我的問題是,貨架記錄仍然被插入。不休眠在事務或批次中插入一個貨架記錄及其相應的書記錄。我想要的是,如果書籍表中的插入由於重複條目而失敗,則不會插入貨架表中的記錄。請告訴我如何實現這一目標。兒童插入在一對多的hibernate映射中失敗(因爲兒童中有一個唯一的鍵),但父母仍然持續

+0

Hibernate做你告訴它做的事情。將事務包含在事務中並在出現問題時進行回滾。 – skuntsel 2013-02-25 12:24:48

回答

0

閱讀第Transaction and concurrency of Hibernate official documentation和應用程序性交易管理原則,你發現有(13.2.1):

Session sess = factory.openSession(); 
Transaction tx = null; 
try { 
    tx = sess.beginTransaction(); 
    //do your database work 
    tx.commit(); 
} 
catch (RuntimeException e) { 
    if (tx != null) tx.rollback(); 
    throw e; // or display error message 
} 
finally { 
    sess.close(); 
} 

否則,尋找容器管理的事務將要處理的事務和會話管理你。

0

,如果你不使用JTA事務處理的類型應該是RESOURCE_LOCAL

<persistence-unit name="PU" transaction-type="RESOURCE_LOCAL">
<non-jta-data-source>java:/comp/env/jdbc/DS</non-jta-data-source>

檢查該樣本檢查您的persistence.xml

EntityManagerFactory emf = Persistence 
     .createEntityManagerFactory("PU"); 
EntityManager em = emf.createEntityManager(); 
try { 
    em.setFlushMode(FlushModeType.COMMIT); 
    em.getTransaction().begin(); 

    BookShelf bs = new BookShelf(); 
    bs.setName("Adventure"); 

    Book b1 = new Book(); 
    b1.setTitle("Spider Man"); 
    bs.addBook(b1); 

    Book b2 = new Book(); 
    b2.setTitle("Spider Man"); //Duplicate 
    bs.addBook(b2); 

    em.persist(bs); 
    try { 
    em.getTransaction().commit(); 
    } catch (Throwable t) { 
    t.printStackTrace(); 
    em.getTransaction().rollback(); 
    } 
} catch (Throwable t2) { 
    t2.printStackTrace(); 
} finally { 
    em.close(); 
    emf.close(); 
} 

BookShelf.java

@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true, mappedBy = "bookShelf")  
private List<Book> bookList; 

public void addBook(Book book) {  
if (bookList == null) { 
    bookList = new java.util.ArrayList<Book>(); 
} 
book.setBookShelf(this); 
bookList.add(book);  
}