Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-06-2010, 21:25   #1
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
[hibernate - java] perché dovrei usare un pattern DAO?

Ciao a tutti, qualunque cosa cerco riguardo a hibernate salta fuori sto pattern DAO, che da quel che ho capito altro non è che che creare una classe che gestisca le CRUD di una "entity"(classe persistente che identifica una tabella nel db).
Ok, ci potrebbe anche stare come idea, ma:
  1. Perché devo soffrire e crearmi per ogni entity una classe per gestirla?
  2. Se poi devo cambiare qualcosa devo modificare la entity, e molto probabilmente anche la classe che ne gestisce le CRUD
  3. Diventa tutto più lungo da fare e da mantenere, allora tanto vale che continuavo ad usare JDBC senza passare ad hibernate no?

Ora mi/vi domando, ma perché mi devo complicare la vita in questo modo usando questo pattern?

Le cose sono due, o non ho capito una mazza(molto molto probabile) o ci si è ingegnati per fare le cose più difficili.

Qualcuno mi potrebbe fare qualche esempio dove l'uso di un pattern DAO mi tornerebbe utile?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:15   #2
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
spiegami, tu vorresti fare le operazioni CRUD direttamente chiamando le api di hibernate nelle tue classi di business??
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:18   #3
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Che intendi per le classi di business?

Io comunque vorrei fare le operazioni che interessano una entity nella entity stessa ( come tra l'altro prevede l'OO), non vedo perché andare a creare un'ulteriore classe per fare ciò, che poi è da mantenere anche quella.

Ci sono motivi di perfomance? Si rompe qualcosa? Non so...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:29   #4
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
il DAO serve per astrarre, dalle tue classi di logica chiami il dao senza sapere cosa hai sotto che fa la persistenza, cosi ti astrai dalla tecnologia e nel caso volessi cambiare implementazione dello strato di persistenza non ci sarebbero problemi
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:31   #5
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da khelidan1980 Guarda i messaggi
il DAO serve per astrarre, dalle tue classi di logica chiami il dao senza sapere cosa hai sotto che fa la persistenza, cosi ti astrai dalla tecnologia e nel caso volessi cambiare implementazione dello strato di persistenza non ci sarebbero problemi
Intendi non ci sarebbero problemi tranne riscrivere il DAO?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:33   #6
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Quote:
Originariamente inviato da MEMon Guarda i messaggi
Intendi non ci sarebbero problemi tranne riscrivere il DAO?
esattamente, altrimenti dovresti toccare tutte le classi, non e niente di più che il concetto di API
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:41   #7
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Intendiamoci, la mia intenzione era quella di fare circa la stessa cosa che si fa per creare un bel DAO, quindi interfaccia, classe astratta che la implementa e finalmente la classe DAO vera, con la sola differenza che la classe DAO finale che estende la classe astratta è la entity stessa!

In questo modo si andrebbero ad aggiungere metodi che in fin dei conti operano direttamente sulla entity nella entity stessa, e in più non ci si ritrova con tante classi, e per quanto mi riguarda non c'è il concetto classe che gestisce->classe gestita che lo trovo illogico.

Ovviamente se non si fa così ci deve essere un motivo...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:55   #8
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
in questo modo sei comunque legato alla tecnologia sottostante, il pattern DAO serve appunto a dissaccoppiare l'implementazione della persistenza dalle tue classi di logica, con l'estensione l'accoppiamento rimane

il concetto classe gestita-classe che gestisce è un classico dei pattern, vedi Delegate
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2010, 23:58   #9
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da khelidan1980 Guarda i messaggi
in questo modo sei comunque legato alla tecnologia sottostante, il pattern DAO serve appunto a dissaccoppiare l'implementazione della persistenza dalle tue classi di logica, con l'estensione l'accoppiamento rimane

il concetto classe gestita-classe che gestisce è un classico dei pattern, vedi Delegate
Sei sempre legato alla tecnologia sottostante a dirla tutta, se si fanno i DAO poi si cambieranno quelli, se si mette tutto nelle entity invece si andranno a toccare le entity... il risultato non cambia in quei termini...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2010, 00:34   #10
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da MEMon Guarda i messaggi
In questo modo si andrebbero ad aggiungere metodi che in fin dei conti operano direttamente sulla entity nella entity stessa, e in più non ci si ritrova con tante classi, e per quanto mi riguarda non c'è il concetto classe che gestisce->classe gestita che lo trovo illogico.

Ovviamente se non si fa così ci deve essere un motivo...
Personalmente non vedo bene l'integrazione delle operazioni di CRUD sulle entity, in quanto significa legare la classe specificatamente all'utilizzo con database, quando in realtà l'entity è (per me) solo un contenitore di dati.
Oltretutto significa che l'entity deve conoscere il database da cui ha origine, ma non necessariamente l'oggetto avrà origine su database: se volessi serializzarla/deserializzarla su file? Se dovessi poi passarla ad un webservice? I metodi read e insert da db non andrebbero più bene.
Se l'entity assume il significato di semplice contenitore di dati, poi posso riutilizzarla meglio in molti più contesti e posso scambiare tra i vari livelli dell'applicazione un oggetto più leggero che non si porta dietro legami con la base dati.
Altro problema che riscontro è la possibilità che venga saltata la logica di business dell'applicativo, ad esempio ci potrebbero esistere degli stati in cui un'operazione CRUD non è ammessa in quanto logicamente sbagliata per condizioni indipendenti dall'entity stessa. Come faccio ad averne il controllo se chiunque abbia un riferimento all'entity può eseguire tali operazioni? Dovrei aggiungere logica dentro l'entity per evitare queste casistiche?

Personalmente trovo molto meglio separare logica e metodi per il CRUD dall'entità che rappresenta i dati
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 22:26   #11
Otaking
Junior Member
 
L'Avatar di Otaking
 
Iscritto dal: Jun 2009
Città: dintorni di Torino
Messaggi: 21
beh il discorso è anche che...se te hai delle delle classiche classi e poi hai le rispettive DAO per fare tutto quello che desideri con un DB, hai sempre ha disposizione le classi base per poter lavorare su altri fronti (esempio NON su un DB).
Se metti tutto nelle entity, rischi di dover poi apportare delle modifiche devastanti... mentre con Hibernate/Dao metti le mani avanti per una gestione più pulita, ottimizzata, pronta per del refactoring, ecc...
Otaking è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 12:38   #12
zakmckraken
Member
 
Iscritto dal: Apr 2004
Messaggi: 56
Giusto per rompere le scatole, carinissimo hibernate, ma se uno deve fare cose meno che semplici inizia ad impazzire con le dipendenze, con i bags, liste collezioni, oggetti che si tirano dietro mezzo database, documentazione mai chiara per le soluzioni che servono..
Ora, lo uso anche io, ma giusto quando mi trovo con un database da 15-20 tabelle max con db di 80/100 Mb ma non mi sognerei mai di andare oltre...

Giusto un opinione, attendo conferme o smentite (anche perche vorrei capirlo meglio sto oggetto blasfemo :P )
zakmckraken è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 13:17   #13
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
ma se un applicazione è pesantemente data-centrica imho tanto vale buttarsi sul pl/sql
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 18:17   #14
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da zakmckraken Guarda i messaggi
Giusto per rompere le scatole, carinissimo hibernate, ma se uno deve fare cose meno che semplici inizia ad impazzire con le dipendenze, con i bags, liste collezioni, oggetti che si tirano dietro mezzo database, documentazione mai chiara per le soluzioni che servono..
Ora, lo uso anche io, ma giusto quando mi trovo con un database da 15-20 tabelle max con db di 80/100 Mb ma non mi sognerei mai di andare oltre...

Giusto un opinione, attendo conferme o smentite (anche perche vorrei capirlo meglio sto oggetto blasfemo :P )
Io sto iniziando ora, le potenzialità sono enormi ma come primo approccio non è dei più semplici.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 23-06-2010, 08:55   #15
zakmckraken
Member
 
Iscritto dal: Apr 2004
Messaggi: 56
Quote:
Originariamente inviato da khelidan1980 Guarda i messaggi
ma se un applicazione è pesantemente data-centrica imho tanto vale buttarsi sul pl/sql
Se pero'deve essere pure portabile so'problemi :P Spesso e volentieri mi sono trovato meglio a gestire la costruzione delle queries con oggetti Java/C#/C (vedi come hanno fatto in Php4Application, giusto per dare un esempio). E'un altro approccio chiaramente, ma se non altro ho pochi (1) posto dove fare le modifiche :P

Zak
zakmckraken è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Un gruppo di ladri ha usato Google Maps ...
Apple non si fida di Samsung per la real...
Windows 11: un nuovo driver nativo mette...
Vi hanno regalato buoni Amazon? Intanto ...
Via acari, polvere e sporco da materassi...
Cuffie Beats in super offerta su Amazon,...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 11:37.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v