Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-11-2011, 16:34   #1
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
[Java/JDBC] Dove memorizzo l'SQL?

Buonasera

Scrivo in Java da poco, quindi sto cercando di far mie le "best pratices" mano a mano che mi si pongono i problemi.

Ora, il dubbio è questo: sto scrivendo un'applicazione in java che si interfaccia con un DB Oracle, ad un livello di interazione tale per cui ORM e simili sono un po' troppo overkill imho. (anche perchè al mio livello attuale ci metterei più tempo a capire come utilizzare l'eventuale framework che altro..).

Per "modellare" rapidamente il codice ho creato una classe SQL che contiene vari membri statici di tipo string, uno per ogni statement. Giusto per riunire il codice SQL in un'unico posto.

Ora, vorrei fare qualcosa di più elegante; avete qualche consiglio in merito? Avevo pensato di racchiudere le query in vari file *.sql in una dir nei pressi del jar di esecuzione, in modo da poterli modificare / ottimizzare senza ricompilare il codice.

Che ne dite? Consigli, critiche e insulti accettati.

Grazie
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-11-2011, 19:41   #2
tacchinox
Member
 
Iscritto dal: Sep 2008
Messaggi: 237
Ciao, ti diro' che a me la classe statica piace.
Io scrivo spesso metodi tipo questo in c#, ma non dovrebbe essere troppo differente in Java:

public static DataTable GetTabellaUtenti()
{
string query = "SELECT * FROM Utenti";
return ExecuteQuery(query);
}

Dove ExecuteQuery è il metodo che gestisce tutta la comunicazione e gli errori con il database.
tipo:
private DataTable ExecuteQuery(string query)
{
Connection conn = new Connection();
try{
etc...
}
catch {display exception}
finally{close connection}
}

L'ho visto fare anche in alcuni video di sviluppatori e mi trovo bene anche perche' arrivo subito alla query, senza dover aprire file di testo e doverli gestire.
tacchinox è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2011, 10:27   #3
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
Anche a me inizialmente piaceva questo approccio, la cosa che mi "spaventa" è che per ogni modifica minima al db bisogna ricompilare tutto.
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2011, 11:17   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12999
L'alternativa sarebbe usare delle Stored Procedures, ovvero creare delle funzioni direttamente nel DB in maniera tale da poterle richiamare con una SELECT semplice.

Il vantaggio è che nel codice avresti solo questo tipo di chiamate, passando eventualmente dei parametri, e giustamente tutto ciò che ha a che fare con il DB è nel DB.

Tra l'altro quest'approccio è tipicamente più sicuro, perché la Stored Procedure accetta solo i parametri che dici te, senza troppi rischi sul piano dell'SQL injection.

Ora, se cambi dettagli interni quest'approccio ti garantisce comunque compatibilità con l'applicazione esistente, ma ovviamente se fai modifiche più consistenti tali da modificare anche i parametri che passi alle funzioni sei comunque costretto a modificare le chiamate nel codice.

In questo senso secondo me la cosa ideale è spendere molto tempo nella fase di progettazione del DB, affinché questo tipo di rischi sia minimizzato.

Un altro svantaggio è che se cambi DB potresti dover ri-scrivere le procedure (anche se credo che per cose non troppo complesse le varie sintassi si equivalgono).

Un'altra possibilità è invece raggruppare le query nella classe che gestisce quel tipo di oggetto, quindi farti una specie di ORM su misura.

Ultima modifica di WarDuck : 27-11-2011 alle 11:19.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
FASTCloud Open Source: un cloud sovrano ...
AMD non lascia spazio a Intel: la top 15...
iPhone 17 torna protagonista su Amazon: ...
PowerToys si aggiorna alla versione 0.10...
La nuova Audi Q7 proietta le frecce sull...
Framework blocca tutto: Laptop 13 Pro no...
SSD, Biwin investe oltre metà del...
Samsung Trend Radar 2026: smartphone e s...
Enel entra nella telefonia mobile: il vi...
Arriva il menu contestuale aggiornato di...
GM punta sulle batterie al sodio per lo ...
Instagram amplia il controllo sull'algor...
Jason Wild: "Siamo bravissimi a ris...
Razer BlackShark V2 X a 34,99€: cuffie e...
d-Matrix avvia la produzione di Corsair:...
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: 20:12.


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