Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-10-2008, 17:03   #1
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
[C#] Hibernate/NHibernate

Ho un problema con NHibernate e immagino che il problema sarebbe lo stesso con Hibernate dato che non trovo una soluzione.
Ho una stored procedure che esegue delle insert e alla fine esegue un update su una tabella su cui ha precedentemente inserito.
Ho ricreato nel codice la logica della stored ma al momento dell'update finale ottengo il messaggio "Unexpected row count: 2; expected: 1". Anche se tiro fuori l'update dalla transazione ottengo lo stesso errore, le insert funzionano ma l'update no.

Inoltre ho un altro problema: richiamando direttamente la stored come NamedQuery: non riesco a trovare il modo di recuperare i valori di ritorno.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 08:12   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Ok per l'aggiornamento è colpa dei trigger, ma cavolo perchè non hanno pensato che esistono pure loro?
A suo tempo sono stati aperti bug sia per Hibernate (2003) sia per NHibernate (2005) e sono stati considerati dei non bug.
In base a quale assurda logica lo sviluppo software deve imporre delle modifiche alla base dati sottostante?
E se questa operazione non fosse possibile?
Non esistono solo sistemi nuovi.

Resta il problema dell'utilizzo delle Stored Procedure.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 08:26   #3
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Questi sono i motivi per cui non mi piacciono i framework ORM che vogliono fare tutto loro.
Preferisco fare le cose da me, oppure usare qualcosa di più light tipo iBatis (c'è anche per .net se ti interessa, può usare stored procedure e offre un meccanismo stile DAO anche lui... anche se è meno invasivo di hibernate).

Tutti i framework comunque richiedono troppi file xml di configurazione per i miei gusti, preferisco tenere la business logic e la parte che interagisce con il DB in classi a se stanti che mi creo da solo.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 09:00   #4
Einstein
Senior Member
 
L'Avatar di Einstein
 
Iscritto dal: Jan 2000
Città: Provincia di Parma
Messaggi: 724
Fermo restando che trovo discutibile l'utilizzo dei triggers se non in casi di auditing/logging e integrità referenziale tra db diversi.
Per l'utilizzo di NHibernate con le stored procedures, prova a vedere se questo ti può aiutare:

http://ayende.com/Blog/archive/2006/...rocedures.aspx

Per quanto riguarda l'utlizzo degli OR/M in generale, è sicuramente un approccio che può dare qualche grattacapo, ma che ritengo indispensabile in applicazioni che usano un Domain Model (http://martinfowler.com/eaaCatalog/domainModel.html) complesso.
__________________
My Pc: Case Enermax Chakra - PSU Corsair HX520 - Gigabyte P35-DS3R - Core2 Duo E6550 - 6 Gb RAM Geil PC800 - 2x WD Caviar SE 320Gb (Raid1) - Xfx GeForce 8600Gt - Master Pioneer DVR111D - Samsung SM T220 - S.O. Windows 7 Ultimate x64 SP1
My blog: http://blogs.ugidotnet.org/alby
Einstein è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 09:13   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Invece a me piacciono parecchio, e da quando li sto utilizzando la produttivita' (e la tranquillta') sono migliorate parecchio. L'XML oramai si puo' quasi sempre generare da solo, anche a partire dagli script SQL di generazione dei database.
Impagabile, davvero impagabile il poter compilare e vedere 0warning 0errors, sapendo che nella compilazione c'e' anche il controllo di tipi e di strutture per la relazione con i database.

In effetti se ci sono dei trigger e' un casino che penso quasi irrisolvibile.
Le stored procedure almeno con LINQ sono supportate. Puoi ridefinire le insert/update/delete non mediante istruzioni SQL autogenerate ma con chiamate a stored procedure esistenti. Questo intendevi?

Penso che una migrazione da un sistema classico esistente ad un ORM sia abbastanza complessa.

Piccola nota di esperienza corrente. Nel mio progetto corrente stiamo usando LINQ, e abbiamo all'inizio avuto un po' di resistenza da parte di DBA e del supporto.
Entrambi vedevano come "scary" la non possibilita' di intervento da parte loro.
Erano abiutato ogni volta che e' possibile ad effettuare modifiche direttamente alle stored procedure invece che al codice, con indubbi vantaggi. Non necessita' di effettuare il deploy su tutte le macchine, nessuna ricompilazione, nessuna interruzione di servizio, etc.
Abbiamo raggiunto un compomesso a mio avviso geniale.
Il database con le tabelle fisiche e' uno schema deciso e organizzato a priori.
Ma ogni tabella viene mappata con viste 1:1 (tranne alcuni casi di parziali denormalizzazioni).
LINQ agisce leggendo solo dalle viste, che per lui sono come tabelle, e le modifiche come insert/update/delete da queste viste vengono passate attraverso stored procedure direttamente da LINQ.
Quindi i DBA e il supporto hanno la possiblita' di cambiare la definizione delle viste e le stored procedure come vogliono. Possono aggiungere/togliere campi e tabelle, basta che alla fine vengano soddisfatte le interfaccie delle viste original.
Una cosa che si perde e' la possiblita' di reverse engineer di visual studio per costruire gli XML di definizione, perche' ovviamente le viste non hanno foreign keys o primary keys, e soprattutto non conoscono le stored procedure di riferimento per le modifiche.
Ma con l'utility grafica di VS e' ancora abbastanza semplice.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 12:22   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da shinya Guarda i messaggi
Tutti i framework comunque richiedono troppi file xml di configurazione per i miei gusti, preferisco tenere la business logic e la parte che interagisce con il DB in classi a se stanti che mi creo da solo.
Gli ORM mica impediscono la separazione della Business Logic. Servono solo per l'implementazione del DAO.
La Microsoft adesso ha tirato fuori l'Entity Framework, che nasconde tramite l'editor i file di configurazione, ma è ancora una bestia oscura e non posso usarlo nel progetto perchè necessita del .NET 3.5 SP1
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 12:26   #7
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Einstein Guarda i messaggi
Fermo restando che trovo discutibile l'utilizzo dei triggers se non in casi di auditing/logging e integrità referenziale tra db diversi.
Nel mio caso sono usati per il log delle modifiche. In ogni caso anche se fossero usati per altro, le mie scelte di programmazione non dovrebbero assolutamente influire su quelle effettuate dai DBA.

Quote:
Per l'utilizzo di NHibernate con le stored procedures, prova a vedere se questo ti può aiutare:

http://ayende.com/Blog/archive/2006/...rocedures.aspx
E' un esempio inutile perchè la stored non ha paramentri in output.

Quote:
Per quanto riguarda l'utlizzo degli OR/M in generale, è sicuramente un approccio che può dare qualche grattacapo, ma che ritengo indispensabile in applicazioni che usano un Domain Model (http://martinfowler.com/eaaCatalog/domainModel.html) complesso.
Infatti, purtroppo l'ambiente Microsoft è tutto orientato ai singoli applicativi e poco allo sviluppo enterprise, anche se col .NET 3.5 SP1 hanno in parte colmato la lacuna.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 12:36   #8
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Invece a me piacciono parecchio, e da quando li sto utilizzando la produttivita' (e la tranquillta') sono migliorate parecchio. L'XML oramai si puo' quasi sempre generare da solo, anche a partire dagli script SQL di generazione dei database.
Personalmente abbiamo dovuto scriverci un applicativo che crei le classi e l'XML, dato che in giro non c'è niente, ma è un continuo mettere le mani agli XML tutte le volte che viene fuori qualcosa di nuovo sulla struttura del DB, e chiaramente grazie alla reflection gli errori vengono fuori a runtime.

Quote:
Impagabile, davvero impagabile il poter compilare e vedere 0warning 0errors, sapendo che nella compilazione c'e' anche il controllo di tipi e di strutture per la relazione con i database.
Con NHibernate? Non significa niente visto che puoi sempre dimenticarti un parametro e scoprire l'errore solo a runtime.

Quote:
In effetti se ci sono dei trigger e' un casino che penso quasi irrisolvibile.
Le stored procedure almeno con LINQ sono supportate. Puoi ridefinire le insert/update/delete non mediante istruzioni SQL autogenerate ma con chiamate a stored procedure esistenti. Questo intendevi?
Con NHibernate ho risolto specificando la query da eseguire durante l'update e impostando di ignorare il conteggio delle righe.
Invece per le stored procedure manca il supporto ai parametri output, con LINQ non ho provato perchè non riesco a configurarlo correttamente, nel mio caso devo usare la SP per salvare 2 o più entità. E in ogni caso è parte del framework 3.5 che non posso usare per vincoli di progetto.

Quote:
Penso che una migrazione da un sistema classico esistente ad un ORM sia abbastanza complessa.
Solo che la tecnologia evolve ma la base dati ha durata infinitamente superiore per cui gli ORM in ambito enterprise dovranno sempre fare i conti con db legacy che non possono essere toccati perchè sopra quei db si fonda già un intero mondo.

Quote:
Piccola nota di esperienza corrente. Nel mio progetto corrente stiamo usando LINQ, e abbiamo all'inizio avuto un po' di resistenza da parte di DBA e del supporto.
Entrambi vedevano come "scary" la non possibilita' di intervento da parte loro.
Erano abiutato ogni volta che e' possibile ad effettuare modifiche direttamente alle stored procedure invece che al codice, con indubbi vantaggi. Non necessita' di effettuare il deploy su tutte le macchine, nessuna ricompilazione, nessuna interruzione di servizio, etc.
Abbiamo raggiunto un compomesso a mio avviso geniale.
Il database con le tabelle fisiche e' uno schema deciso e organizzato a priori.
Ma ogni tabella viene mappata con viste 1:1 (tranne alcuni casi di parziali denormalizzazioni).
LINQ agisce leggendo solo dalle viste, che per lui sono come tabelle, e le modifiche come insert/update/delete da queste viste vengono passate attraverso stored procedure direttamente da LINQ.
Quindi i DBA e il supporto hanno la possiblita' di cambiare la definizione delle viste e le stored procedure come vogliono. Possono aggiungere/togliere campi e tabelle, basta che alla fine vengano soddisfatte le interfaccie delle viste original.
Una cosa che si perde e' la possiblita' di reverse engineer di visual studio per costruire gli XML di definizione, perche' ovviamente le viste non hanno foreign keys o primary keys, e soprattutto non conoscono le stored procedure di riferimento per le modifiche.
Ma con l'utility grafica di VS e' ancora abbastanza semplice.
L'obiettivo è quello, il problema è che il database è praticamente impossibile da modificare visto le migliaia di applicativi che vi ruotano intorno.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2008, 16:45   #9
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Gli ORM mica impediscono la separazione della Business Logic. Servono solo per l'implementazione del DAO.
Mi sono spiegato male. Intendevo dire che preferisco gestirmi la separazione della logica e i DAO da solo, senza xml, ma attraverso convenzioni. Questo perchè...

Quote:
Originariamente inviato da tomminno
Personalmente abbiamo dovuto scriverci un applicativo che crei le classi e l'XML, dato che in giro non c'è niente, ma è un continuo mettere le mani agli XML tutte le volte che viene fuori qualcosa di nuovo sulla struttura del DB...
...e quando xml diventa anch'esso un linguaggio di programmazione, è l'inizio della fine.
shinya è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Sempre più pubblicità su YouTube: arriva...
Polestar fa +80% in Italia e tocca quota...
Il tuo Mac smette di connettersi a Inter...
La nuova alleanza Intel-Google ridefinis...
Energia troppo cara, regole da rivedere:...
CPU che si piegano e miglior contatto: I...
Addio Volkswagen Touareg? Non proprio: i...
PS5 Slim 1 TB in bundle con Fortnite Flo...
Addio desktop ingombranti: questo mostro...
La fame di memoria dell'AI non si fermer...
Instagram, nuove restrizioni per i teena...
LinkedIn introduce il controllo della ve...
Attacco a Magento: ecco come un'immagine...
Un nuovo State of Play potrebbe arrivare...
App IO e IT-Wallet: i 14enni potranno ac...
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: 15:51.


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