Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-05-2011, 14: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, 15: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, 15: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, 15: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, 15: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, 15: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, 16: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, 16: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


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Assassin's Creed Black Flag Resynced pot...
Gli USA dicono no a Polestar, sì a Volvo...
Steam Machine dovrebbe costare 700 dolla...
Microsoft 365, l'Antitrust apre un'istru...
400 editori contro OpenAI e Microsoft: s...
Notion interrompe il suo client email ba...
Italia e Tunisia realizzano il primo col...
Ecco perché tutti parlano di questi robo...
IBM: il quantum computing entra nell’ind...
Xcode 26.6 aggiunge Google Gemini: ora i...
Bungie e Sony licenziano metà stu...
La copia fisica di Marvel's Wolverine co...
Il terremoto in Venezuela e i 30 secondi...
Addio ansia da pacco: Google Wallet moni...
L'umanesimo di Ford: rafforzato il ruolo...
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: 14:14.


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