Đang chuẩn bị liên kết để tải về tài liệu:
Java Persistence with Hibernate phần 7
Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
bạn nói đúng. Tuy nhiên, nó không phải là nhất thiết phải là điều tương tự. Chúng tôi phải tiếp cận từng bước, cho bây giờ, hãy xem xét một đơn vị làm việc một trình tự đặc biệt thay đổi trạng thái đối tượng của bạn mà bạn muốn nhóm lại với nhau. | Conversations with Hibernate 489 the user Sorry somebody modified the same auction and force a restart of the conversation from step one. How can you make the conversation atomic The conversation spans several persistence contexts and several database transactions. But this isn t the scope of a unit of work from the point of view of the application user she considers the conversation to be an atomic group of operations that either all fail or all succeed. In the current conversation this isn t a problem because you modify and persist data only in the last second step. Any conversation that only reads data and delays all reattachment of modified objects until the last step is automatically atomic and can be aborted at any time. If a conversation reattaches and commits modifications to the database in an intermediate step it s no longer atomic. One solution is to not flush the persistence contexts on commit that is to set a FlushMode.MANUAL on a Session that isn t supposed to persist modifications of course not for the last step of the conversation . Another option is to use compensation actions that undo any step that made permanent changes and to call the appropriate compensation actions when the user aborts the conversation. We won t have much to say about writing compensation actions they depend on the conversation you re implementing. Next you implement the same conversation with a different strategy eliminating the detached object state. You extend the persistence context to span the whole conversation. 11.2.3 Extending a Session for a conversation The Hibernate Session has an internal persistence context. You can implement a conversation that doesn t involve detached objects by extending the persistence context to span the whole conversation. This is known as the session-per-conversation strategy as shown in figure 11.3. A new Session and persistence context are opened at the beginning of a conversation. The first step loading of the Item object is implemented