Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-05-2010, 12:15   #1
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
[C#] database collegato ma le query non fanno nulla

salve a tutti ho un problema da cui non riesco a venire fuori
sto facendo una programma che gestisce un db access 2003 (.mdb)

lo ho collegato al database e mi sono ricavato la stringa di connessione dal file app.config come è suggerito sul manuale di visual studio e la utilizzo per fare query sul database alla pressione di certi pulsanti sull'interfaccia.
Il problema è che pur non avendo errori nè di compilazione nè di esecuzione la query non fa nulla sul db

nel codice di esempio ho imposto di cancellare un preciso record inserito nella tabella su cui voglio fare la query
Codice:
private static string source = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\EssicatoioGUI.mdb;";

private int current = 214;

private void elimina_Click(object sender, EventArgs e)
        {
            
            using(OleDbConnection con = new OleDbConnection(source))
            {
                con.Open();
                
                    string query_elimina = "DELETE FROM t_pesata 
                     WHERE idcarico = " + current.ToString();
                    OleDbCommand execute = 
                        new OleDbCommand(query_elimina, con);

                    con.Close();

                    MessageBox.Show("Pesata eliminata");
                    
                }


            }
dopo la pressione del bottone sull'interfaccia mi viene fuori il messaggio di conferma ma quando controllo il database il record è ancora lì

come posso fare? dove è che sbaglio?
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2010, 14:18   #2
Jay85
Member
 
Iscritto dal: Dec 2008
Messaggi: 90
Quote:
Originariamente inviato da tribalspirit Guarda i messaggi
salve a tutti ho un problema da cui non riesco a venire fuori
sto facendo una programma che gestisce un db access 2003 (.mdb)

lo ho collegato al database e mi sono ricavato la stringa di connessione dal file app.config come è suggerito sul manuale di visual studio e la utilizzo per fare query sul database alla pressione di certi pulsanti sull'interfaccia.
Il problema è che pur non avendo errori nè di compilazione nè di esecuzione la query non fa nulla sul db

nel codice di esempio ho imposto di cancellare un preciso record inserito nella tabella su cui voglio fare la query
Codice:
private static string source = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\EssicatoioGUI.mdb;";

private int current = 214;

private void elimina_Click(object sender, EventArgs e)
        {
            
            using(OleDbConnection con = new OleDbConnection(source))
            {
                con.Open();
                
                    string query_elimina = "DELETE FROM t_pesata 
                     WHERE idcarico = " + current.ToString();
                    OleDbCommand execute = 
                        new OleDbCommand(query_elimina, con);

                    con.Close();

                    MessageBox.Show("Pesata eliminata");
                    
                }


            }
dopo la pressione del bottone sull'interfaccia mi viene fuori il messaggio di conferma ma quando controllo il database il record è ancora lì

come posso fare? dove è che sbaglio?
beh semplice, in realtà non esegui niente...
OleDbCommand execute =
new OleDbCommand(query_elimina, con);
questo codice non basta... devi aggiungere nella riga successiva:
Quote:
execute.executeReader();
o una cosa simile...nel senso che dipende dal risultato che vuoi ottenere...per non sbagliare usa quello che ti ho scritto...
Jay85 è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2010, 14:31   #3
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
mo provo e ti faccio sapere..
ma mi si è accesa una lampadina rileggendo meglio il manuale
credo che il comando più appropriato sia ExecuteNonQuery() visto che non deve ritornare nulla
ExecuteReader() credo serva quando si vuole fare una vista delle modifiche o cmq quando si fa una query SELECT
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2010, 16:13   #4
Jay85
Member
 
Iscritto dal: Dec 2008
Messaggi: 90
Quote:
Originariamente inviato da tribalspirit Guarda i messaggi
mo provo e ti faccio sapere..
ma mi si è accesa una lampadina rileggendo meglio il manuale
credo che il comando più appropriato sia ExecuteNonQuery() visto che non deve ritornare nulla
ExecuteReader() credo serva quando si vuole fare una vista delle modifiche o cmq quando si fa una query SELECT
si esatto ... per quello ti ho detto dipende da cosa vuoi ottenere... vedrai che ora ti funziona
Jay85 è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2010, 18:53   #5
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
non funziona... il record con id 214 rimane lì tranquillo

ho provato anche a cambiare la query in maniera che l'eliminazione di tutta la riga fosse esplicita e ho pure cambiato il metodo di connessione

ho provato anche a mettere il valore fra due apici ('214') ma mi lancia un'eccezione e comunque non fa quello che deve fare

il codice ora è così

Codice:
private int current = 214;
        //stringa di connessione 
        private static string source = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\EssicatoioGUI.mdb;";

 private void elimina_Click(object sender, EventArgs e)
        {
            
            OleDbConnection con = new OleDbConnection(source);
           
                    con.Open();
                    string valore = current.ToString();
                    string query_elimina = "DELETE t_pesata.* FROM t_pesata WHERE t_pesata.idcarico = " + valore;
                    OleDbCommand execute = new OleDbCommand(query_elimina, con);
                    
                    int rowsreturned = execute.ExecuteNonQuery();
                    con.Close();

                    MessageBox.Show("Pesata eliminata");
                    
}
il bello è che gli faccio stampare il numero delle righe che sono state influenzate dalla query mi ritorna il valore corretto (1)

non è che la cosa ha effetto solo se produco ed installo l'eseguibile?


EDIT:ho fatto altre prove e le query di select mi restituiscono i risultati corretti...
non capisco perchè non posso cancellare o modificare dati del database nonostante sia impostato ad accesso libero
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame

Ultima modifica di tribalspirit : 14-05-2010 alle 19:23.
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2010, 11:07   #6
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
up
per riassumere riesco a leggere il db ma non riesco a modificarlo da c#
mentre se eseguo le query di aggiornamento o eliminazione da dentro access, queste funzionano

non è che devo cambiare qualche opzione in access?
il file è di tipo access 2003
come programmi sto utilizzando visual studio 2008, office 2007, windows xp x86
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2010, 11:14   #7
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Non ho mai usato un DB così ma visto che il comando sembra eseguire correttamente ma lo stato del database non cambia non è che vuole un commit alla fine dell'esecuzione?

Guardando il codice direi che con.Close() potrebbe già fare il commit di suo ma non sò.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2010, 11:48   #8
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
ho seguito alla lettera 10000 guide che alla fine dicono tutte la stessa cosa.. infatti non ho assolutamente errori di compliazione od esecuzione..
ne sto uscendo pazzo
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2010, 18:37   #9
tribalspirit
Senior Member
 
L'Avatar di tribalspirit
 
Iscritto dal: Mar 2009
Messaggi: 3188
up
nessuno ha mai avuto un problema simile?
__________________
Concluso positivamente con: speck, JKT, Buell72, Black_Air,dejan_465
btag: UnluckyEvent#2334 steamID:toomuchshame
tribalspirit è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 09:46   #10
Jay85
Member
 
Iscritto dal: Dec 2008
Messaggi: 90
Guarda ti devo dire che l'unica volta in cui una query non mi funzionava era perchè ovviamente non avevo eseguito la query. Io solitamente utilizzo sql quindi ti faccio un esempio così proprio perchè sono sicura funzioni. Alla fine tutte le query sono uguali.

Quote:
//Apro la connessione
this.Conn.open();
//Scrivo la query di delete
SqlCommand cmdDelete = new SqlCommand("DELETE FROM tabella", this.Conn);
//Eseguo
cmdDelete.ExecuteNonQuery();
//Chiudo la connessione
this.Conn.close();
Se vuoi che ti aiuti di più pubblica il codice
Jay85 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Riceve il reso di una RTX 5090 da 4.000 ...
Gli utenti con GPU Intel non possono gio...
Un agente AI visita 5.000 siti dove un u...
IA, virtualizzazione e cyber resilienza:...
AMD aggiorna FSR alla versione 4.1. Migl...
Nuovi suffissi internet 2026: per la sec...
Claudy Day: tre vulnerabilità in ...
Record di efficienza per i pannelli sola...
SteamOS 3.8 è disponibile in ante...
Opel in Formula E dalla Stagione 13: con...
Windows 11 26H1: ecco le scadenze esatte...
Arriva HiSecEngine USG6000G, la nuova ga...
Xiaomi SU7 2026 ufficiale con 902 km di ...
Il tuo vecchio iPhone potrebbe essere gi...
Già disponibile un primo aggiorna...
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: 07:49.


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