Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-05-2011, 15:56   #1
agosteeno
Member
 
Iscritto dal: Aug 2009
Messaggi: 119
[java] DB derby embedded: risultato query

Salve a tutti, per una mia applicazione ho un server che ha un suo database derby di tipo embedded. Siccome non ho mai usato un db in una applicazione ho un dubbio per quanto riguarda le query di tipo select from where.
Per quanto riguarda il risulultato di queste query, come faccio a deserializzare il risultato? Non so' proprio cosa devo fare.
In pratica avrei un metodo chiamato MieiDati getDati(int param1, String param2) che preleva i dati necessari a creare l'oggeto MieiDati dal db e dove i parametri del metodo sono i parametri where della query string. Io faccio una cosa del genere:
Codice:
public MieiDati getDati(int param1, String param2){
                Connection conn = null;
		String driver = "org.apache.derby.jdbc.EmbeddedDriver";
		String dbName = "MioDB";
		String connectionURL = "jdbc:derby:" + dbName + ";create=true";
		int esito = 0;
		try {
			Class.forName(driver);
		} catch (java.lang.ClassNotFoundException e) {
			System.out.println("Classpath errato!");
		}

		try {
			conn = DriverManager.getConnection(connectionURL);
		} catch (Throwable e) {
			System.out.println("Problema nella connessione!");
		}

		String sqlGetDati = "SELECT Dato1, " 
			+ "Dato2, "
				+ "Dato3, " 
				+ "FROM TABELLA "
				+ "WHERE (Campo1 =" + param1 + " AND Campo2 = " + param2+ ");";

		PreparedStatement prepGeDati = null;
		try {
			prepGetDati = conn.prepareStatement(sqlGetDati);
		
			prepGetDati.execute(sqlGetDati);
			
			/* qua non so' come ottenere il risultato della query */

			// controlla esito
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

...
	}
Ma poi non so' come ottenere i dati per creare un oggetto di tipo MieiDati da restituire.
Qualcuno mi sa' dare un aiuto, anche solo il link ad un tutorial per esempio. Grazie in anticipo!
agosteeno è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 16:18   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Premetto che l'uso "nudo e crudo" del package sql è un po' masochistico, potresti avere qualche aiuto da JPA - usi il database come prima ma anzichè gestire query e result set a mano partono e arrivano delle istanze di classi come fossero dei java-bean.

Qui c'è un sunto anche se la fa molto più "profescional" di com'è in realtà:

http://www.oracle.com/technetwork/ar...pa-137156.html

Fatta la premessa, una volta invocato "execute" ottieni i dati con:

ResultSet risultati = prepGetDati.getResultSet();

Puoi anche dire:

ResultSet risultati = prepGetDati.executeQuery();

al posto di "execute()", è la stessa cosa.

Dalla javadoc vedi poi come funziona un ResultSet ma è in sostanza un cursorse che va avanti (e a volte indietro) sulle righe di una tabella virtuale: una volta puntato sulla riga pigli i valori per colonna.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 16:22   #3
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Qui c'è un tutorial più digeribile su jpa

http://java.sun.com/developer/techni...ersistenceapi/
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 16:30   #4
agosteeno
Member
 
Iscritto dal: Aug 2009
Messaggi: 119
Grazie mille. Ora ci smanetto un po' su'.
Comunque, giusto per vedere se ho capito, se faccio una cosa del genere:
Codice:
...
prepGetDati = conn.prepareStatement(sqlGetDati);
ResultSet risultati = prepGetDati.executeQuery();
String primoRisultatoCheAspetto = risultati.getString(1);
...
int ennesiomoRisultatoCheAspetto = risultati.getInt(n);
...
nelle variabili dovrei avere gli elementi ottenuti dall'esecuzione della query? Ho capito bene? Tra l'altro ho visto che le stesse funzioni (getInt, getString) oltre a prendere l'indice di colonna prendono anche String columnLabel. Questo credo sia il nome del parametro della select, o sbaglio?
agosteeno è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 16:48   #5
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Quasi.

Il ResultSet restituito dallo statement inizialmente punta alla riga "-1". Lo fa perchè è pensato per essere usato in un ciclo.

Codice:
ResultSet rs = stat.getResultSet();//rs punta alla riga -1
while(rs.next()) {//passa alla riga successiva, la prima volta da -1 a 0
    ...rs.get... bla bla
}
Se lo usi fuori dal ciclo devi dirgli next()

Codice:
ResultSet rs = stat.getResultSet();
rs.next();//se non ci sono risultati next() restituisce false
...leggi rs
Esatto per quanto riguarda accesso per indice e nome di colonna. Tieni sempre conto, come hai fatto, che la prima colonna ha indice 1.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 16:58   #6
agosteeno
Member
 
Iscritto dal: Aug 2009
Messaggi: 119
Credo di aver capito: in pratica prima di fare un rs.getInt(perEsempio) devo fare un if(rs.next()); o qualcosa del genere. Quindi il codice che ti ho scritto prima diventerebbe una cosa di questo tipo:
Codice:
prepGetDati = conn.prepareStatement(sqlGetDati);
prepGetDati.executeQuery();
ResultSet risultati = prepGetDati.getResultSet();
if(risultati.next())
{
   String primoRisultatoCheAspetto = risultati.getString(1);
}
...
if(risultati.next())
{
   int ennesiomoRisultatoCheAspetto = risultati.getInt(n);
}
...
e cosi' via per tutti i dati che mi aspetto siano nella stringa di risposta?

Ti ringrazio tantissimo!
agosteeno è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 17:34   #7
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Oserei un no.

Il next sposta il cursor-resultset da una riga a quella successiva. Poi quando ti sei appostato su una riga, "scorri" lungo le colonne usando l'indice dei vari get.

Cioè:

Codice:
ResultSet rs = ...
if(rs.next()) {//se c'è almeno una riga
    riga1colonna1 = rs.get(1);
    riga1colonna2 = rs.get(2);
    riga1colonnaN = rs.get(N);
}
if(rs.next()) {//se ci sono almeno due righe...
    riga2colonna1 = rs.get(1);
    riga2colonna2 = rs.get(2);
    riga2colonnaN = rs.get(N);
}
...
if(rs.next()) {//eccetera
Se il risultato che ti aspetti è composto di una sola riga o se ti interessa solo la prima riga allora ti basterà dire:

Codice:
ResultSet rs = ...
if(rs.next()) {
   e qui prendi le colonne della prima riga
}
Riassumendo: il next scorre le righe, non le colonne.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 17:55   #8
agosteeno
Member
 
Iscritto dal: Aug 2009
Messaggi: 119
Ah ecco! Infatti non mi era tornata chiara la storia della riga! Che stupido: siccome nell'esempio che mi sono creato ritorna un solo valore allora non stavo pensando che i risultati potrebbero essere tanti! ahahahah grazie mille!
agosteeno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Scope elettriche in offerta su Amazon: f...
iPhone 17 Pro a un nuovo minimo storico ...
DJI Mini 4 Pro Fly More Combo a 859€ su ...
Roborock in offerta su Amazon: QV 35A e ...
Crisi della RAM: Intel rassicura sul mer...
Dreame taglia i prezzi su Amazon: L40 Ul...
ChatGPT, arrivano gli annunci pubblicita...
iPhone Air a un nuovo minimo storico su ...
Datacenter e materie prime: Amazon acqui...
StackWarp: una nuova vulnerabilità...
Il telescopio spaziale James Webb ha cat...
Il razzo spaziale europeo Ariane 6 lance...
Il lander lunare Blue Origin Blue Moon M...
Gli LLM riescono a risolvere problemi ma...
Smettila con quei cioccolatini. Per San ...
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: 10:48.


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