Loading presentation...

Present Remotely

Send the link below via email or IM

Copy

Present to your audience

Start remote presentation

  • Invited audience members will follow you as you navigate and present
  • People invited to a presentation do not need a Prezi account
  • This link expires 10 minutes after you close the presentation
  • A maximum of 30 users can follow your presentation
  • Learn more about this feature in our knowledge base article

Do you really want to delete this prezi?

Neither you, nor the coeditors you shared it with will be able to recover it again.

DeleteCancel

Make your likes visible on Facebook?

Connect your Facebook account to Prezi and let your likes appear on your timeline.
You can change this under Settings & Account at any time.

No, thanks

Mapowanie relacyjno-obiektowe prawdziwych obiektów

No description
by

Sławek Sobótka

on 14 May 2015

Comments (0)

Please log in to add your comment.

Report abuse

Transcript of Mapowanie relacyjno-obiektowe prawdziwych obiektów

Mapowanie relacyjno - o b i e k t o w e
prawdziwych obiektów

Czym jest obiekt?
Obiekt
Struktura danych
Funkcja
Procedura
class
Dobry obiekt:
apatyczny
introwertyczny
samolubny
Paradygmat
abstrakcja
enkapsulacja
polimorfizm
dziedziczenie
Boczne kółka
SOLID
GRASP
RDD
Wzorce projektowe
Lazy Loading
Cascading
Optimistic Locking
ID
TX
noSQL
t
<<Aggregate>>
<<Aggregate>>
<<Aggregate>>
Reservation
Sorry, taki
mamy
język
Rozwiązanie
Koszt całkowity jest wartością funkcji*
{begin commit}
Eager Loading całego agregatu
Blokowanie optymistyczne do odczytu
- chyba, że kalukacja jest kosztowna
- jeżeli granica agregatu jest dobrze określona
- Eager, ale jak? JOIN, SELECT, SUBSELECT
- Torba (List) czy Lista (List + @IndexColumn)
- sprawdza wersję obiektów, które nie uległy zmianie
entityManager.lock(reservation, OPTIMISTIC);
Sławomir Sobótka
Rezerwacja -> Faktura
t
Rozwiązanie
Blokowanie optymistyczne do zapisu
- sprawdza wersję obiektów, które nie uległy zmianie
i zwiększa ją
entityManager.lock(order, OPTIMISTIC_FORCE_INCREMENT);
t
t
Reservation
version = 5
Client Data
version = 2
Shipment
version = 3
Mapowanie dobrze
zdefiniowanych obiektów

Odczyt
Eager (Join)
lock OPTIMISTIC
Zapis
Cascade = ALL, orphanRemoval = true
lock OPTIMISTIC_FORCE_INCREMENT
Mapowanie
ID - ???
Set
Repozytoria
Jak powinien brzmieć komentarz?
Empiryczne Prawo cieknącej abstrakcji Joela Spolskyego:

"każda
nietrywialna
abstrakcja
cieknie"
Wszystko co musisz wiedzieć o JPA
http://bottega.com.pl/artykuly-i-prezentacje
https://github.com/BottegaIT/ddd-leaven-v2
Cieknąca abstrakcja
WTF?!?
GRANICA AGREGATU
Credits: Paweł Szulc
DAO
Serwis
GUI

(kontroler/prezenter)
"Jeżeli ktoś odróżnia naukę od zabawy,
to nie zrozumiał żadnego z tych pojęć"
Reservation
version: 5
totalCost: 2
items: {
prod1,
prod2}
Modelowanie
niezmienników
a + b = c
<<Aggregate>>
<<Aggregate>>
<<Aggregate>>
Full transcript