|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 841
|
[SQL] select con condizione where...
Salve,
Come posso passare ad una query, come condizione "where", il contenuto di una variabile? Non sono sicuro di riuscire a spiegarmi, ci provo: Ho un metodo (in Java) al quale passo come parametro una variable intera. dovrei fare una select in una tabella che come condizione di "where" abbia il valore di quella variabile, però non conosco bene la sintassi. devo fare un qualcosa di questo tipo?: Codice:
public void controlloEsistenza(int codice){ try { conn.setAutoCommit(false); conn.commit(); String sql = "select prv_java_anagra.codice where (prv_java_angra.coice = ) values(?)"; PreparedStatement dbst; dbst = conn.prepareStatement(sql); dbst.clearParameters(); conn.commit(); conn.setAutoCommit(true); }catch(Exception ex) { //System.out.println("Inserimento fallito"); //System.out.println("Errore : " + ex.toString()); try { conn.rollback(); } catch(SQLException ex2) { System.out.println("Eccezione SQL!"); ex2.printStackTrace(); } } }
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza... ...Excusatio non petita, accusatio manifesta... Bruno Boschi |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2774
|
Devi fare una semplice concatenazione di stringhe
|
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 841
|
Che intendi dire?
Devo concatenare i dati del resultset in un vettore di stringhe o qualcosa di simile?
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza... ...Excusatio non petita, accusatio manifesta... Bruno Boschi Ultima modifica di ShadowX84 : 03-07-2007 alle 10:03. |
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: Oct 2004
Città: Acireale
Messaggi: 447
|
Prima di tutto c'è la query sbagliata. Non hai specificato la tabella da cui prelevare i dati. Un esempio di query potrebbe essere
Codice:
SELECT name FROM students WHERE code = ? Codice:
public void controlloEsistenza(int codice){ try { conn.setAutoCommit(false); conn.commit(); String sql = "SELECT name FROM students WHERE code = ?" PreparedStatement dbst; dbst = conn.prepareStatement(sql); dbst.clearParameters(); dbst.setInt(1,400932); conn.commit(); conn.setAutoCommit(true); }catch(Exception ex) { //System.out.println("Inserimento fallito"); //System.out.println("Errore : " + ex.toString()); try { conn.rollback(); } catch(SQLException ex2) { System.out.println("Eccezione SQL!"); ex2.printStackTrace(); } } } Questo perché potrebberò sorgere problemi grossi di sicurezza e di query injection. ![]()
__________________
Ho concluso acquisti e/o vendite con : SHIVA>>LuR<<, TheGaiden, ArvMau |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2774
|
Non se fai i dovuti replace.. o almeno credo, c'è un modo per iniettare anche se faccio i replace?
|
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 414
|
bè il PreparedStatement spesso si occupa di fare solo dei replace ... ma la differenza sta sempre nell'implementazione che dipende dal database che stai utilizzando!
Per gestire tu tutti i replace dovresti saperli ... e magari ti sfugge sempre qualcosa .... e poi se nel caso cambi il database deri rivisitare tutto il codice ![]() con il PS fa tutto lui e sei salvo da aventuali cambi di database .... comunque se riesci a fare tutti i giusti 'escape' (fatti con il replace) stai sicuro! |
![]() |
![]() |
![]() |
#7 | |||
Senior Member
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 841
|
Quote:
![]() Quote:
Quote:
Quindi un'implementazione corretta potrebbe essere questa? Codice:
public void controlloEsistenza(int codice){ try { conn.setAutoCommit(false); conn.commit(); String sql = "SELECT codice FROM prv_java_anagra WHERE codice = ?" PreparedStatement dbst; dbst = conn.prepareStatement(sql); dbst.clearParameters(); dbst.setInt(1,400932); conn.commit(); conn.setAutoCommit(true); }catch(Exception ex) { //System.out.println("Inserimento fallito"); //System.out.println("Errore : " + ex.toString()); try { conn.rollback(); } catch(SQLException ex2) { System.out.println("Eccezione SQL!"); ex2.printStackTrace(); } } } il ? nella query, starebbe a rappresentare il valore che passo ogni volta che richiamo il comando dbst.setInt()?
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza... ...Excusatio non petita, accusatio manifesta... Bruno Boschi |
|||
![]() |
![]() |
![]() |
#8 | |
Senior Member
Iscritto dal: Oct 2004
Città: Acireale
Messaggi: 447
|
Quote:
Per esempio, supponendo di voler passare una stringa possiamo utilizzare il metodo setString. Nella documentazione ufficiale c'è scritto : Sets the designated parameter to the given Java String value. The driver converts this to an SQL VARCHAR or LONGVARCHAR value (depending on the argument's size relative to the driver's limits on VARCHAR values) when it sends it to the database. Quindi, sempre in teoria, il quoting dovrebbe essere automatico, o no ? ![]()
__________________
Ho concluso acquisti e/o vendite con : SHIVA>>LuR<<, TheGaiden, ArvMau |
|
![]() |
![]() |
![]() |
#9 | |
Senior Member
Iscritto dal: Oct 2004
Città: Acireale
Messaggi: 447
|
Quote:
Spero di essere stato chiaro.... ![]()
__________________
Ho concluso acquisti e/o vendite con : SHIVA>>LuR<<, TheGaiden, ArvMau |
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:57.