Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-07-2007, 09:11   #1
ShadowX84
Senior Member
 
L'Avatar di ShadowX84
 
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 842
[JAVA-SQL]: La delete non funziona, ma il codice non da errori.

Salve,

Ho qui un metodo che dovrebbe cancellare un record da una tabella, il programma non mi rileva errori e va in esecuzione, quando però arriva il momento di eseguire la query, mi genera un eccezione SQL, qualcuno può indicarmi dove stò sbagliando?

Codice:
public int cancellaRecord(String cognome){
        try{
            conn.setAutoCommit(false);
            conn.commit();
            String sql = "delete form prv_java_anagra where cognome = ?";
            PreparedStatement dbst;
            dbst = conn.prepareStatement(sql);
            dbst.clearParameters();
            try{
                dbst.setString(3, cognome);
                dbst.executeUpdate();
            }catch(SQLException ex){
                return 1;
            }
            conn.commit();
            conn.setAutoCommit(true);
        }catch(Exception ex){
            try{
                conn.rollback();
            }catch(SQLException ex2){
                return 1;
            }
            return 2;
        }
        return 0;
    }
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza...
...Excusatio non petita, accusatio manifesta...
Bruno Boschi
ShadowX84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 09:19   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da ShadowX84 Guarda i messaggi
dbst.setString(3, cognome);
A "occhio" (e nota non conoscendo JDBC), direi che quel 3 non va, visto che hai solo 1 parametro.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 09:29   #3
ShadowX84
Senior Member
 
L'Avatar di ShadowX84
 
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 842
Quote:
Originariamente inviato da andbin Guarda i messaggi
A "occhio" (e nota non conoscendo JDBC), direi che quel 3 non va, visto che hai solo 1 parametro.

Si, in effetti non è motlo logico.

Avevo provato anche mettendoci 1, ma il risulatato non cambia, la risposta che ottengo è sempre un'eccezione.
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza...
...Excusatio non petita, accusatio manifesta...
Bruno Boschi
ShadowX84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 12:00   #4
ShadowX84
Senior Member
 
L'Avatar di ShadowX84
 
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 842
Altri consigli e/o suggerimenti?
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza...
...Excusatio non petita, accusatio manifesta...
Bruno Boschi
ShadowX84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 13:12   #5
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Non è che semplicemente hai sbagliato a scrivere nel comando sql?

Codice:
String sql = "delete form prv_java_anagra where cognome = ?";

Non dovrebbe essere "from" ??
Inoltre ho un altro piccolo dubbio;

Il valore che devi confrontare (cognome) sembra essere associato ad un sql parameter (il tuo "?"), ma dove hai inizializzato il sql parameter per dirgli che il suo valore è "cognome" ?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 13:43   #6
ShadowX84
Senior Member
 
L'Avatar di ShadowX84
 
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 842
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Non è che semplicemente hai sbagliato a scrivere nel comando sql?

Codice:
String sql = "delete form prv_java_anagra where cognome = ?";

Non dovrebbe essere "from" ??
Inoltre ho un altro piccolo dubbio;

Il valore che devi confrontare (cognome) sembra essere associato ad un sql parameter (il tuo "?"), ma dove hai inizializzato il sql parameter per dirgli che il suo valore è "cognome" ?
===> ===> ===>

2 Giorni...D U E giorni...

Adesso funziona tutto correttamente.
Grazie mille.
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza...
...Excusatio non petita, accusatio manifesta...
Bruno Boschi
ShadowX84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 13:59   #7
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da ShadowX84 Guarda i messaggi
===> ===> ===>

2 Giorni...D U E giorni...

Adesso funziona tutto correttamente.
Grazie mille.
Di nulla...

Se posso però darti un piccolo consiglio su una delete da una tabella, faresti meglio a non usare il cognome come valore di riferimento.

Fin quando hai tutti cognomi diversi, va bene, ma se per caso hai due o più persone con lo stesso cognome le elimini tutte.

Non avrebbe senso nemmeno metterci un LIMIT 1 per eliminarne uno solo... difatti come farebbe il programma a capire quale nello specifico eliminare?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2007, 14:08   #8
ShadowX84
Senior Member
 
L'Avatar di ShadowX84
 
Iscritto dal: Jul 2002
Città: Soci (AR)
Messaggi: 842
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Di nulla...

Se posso però darti un piccolo consiglio su una delete da una tabella, faresti meglio a non usare il cognome come valore di riferimento.

Fin quando hai tutti cognomi diversi, va bene, ma se per caso hai due o più persone con lo stesso cognome le elimini tutte.

Non avrebbe senso nemmeno metterci un LIMIT 1 per eliminarne uno solo... difatti come farebbe il programma a capire quale nello specifico eliminare?
I consigli son sembre bene accetti

Avevo pensato al problema di un doppio cognome, o anche di omonimia, e durante lo sviluppo di questo programmino vedrò di gestire tali circostanze.

La mia attuale esigenza era che funzionasse quel metodo.
E' un programma che stò "sviluppando" per togliermi un pò di ruggine e soprattutto per imparare un pò di basi di programmazione, quindi è tutt'altro che un'opera "perfetta"

Grazie ancora
__________________
...Fatti non foste a viver come bruti ma per seguir virtute e canoscenza...
...Excusatio non petita, accusatio manifesta...
Bruno Boschi
ShadowX84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
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:50.


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