Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-11-2011, 17: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, 20: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, 11: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, 12:17   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12936
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 12:19.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
SpaceX vuole portare nello Spazio 1 mili...
Realme 16: il nuovo mid-range che si isp...
DAZN lancia il piano Full Mobile a 19,99...
Samsung Galaxy S26, ormai è tutto...
Smartphone sempre più cari: super...
L'ultima puntata di Falsissimo rimossa d...
NASA Perseverance ha utilizzato percorsi...
Blue Origin sospende per almeno due anni...
Stampanti, Los Angeles verso il divieto ...
Roscosmos Amur: il razzo spaziale riutil...
Robot aspirapolvere per tutte le tasche:...
Accedere alle mail di un lavoratore lice...
Amazon Haul scatenato: migliaia di prodo...
Amazon Seconda Mano rilancia: sconto ext...
Super prezzo Amazon per ECOVACS DEEBOT T...
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: 21:47.


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