|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
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");
}
}
come posso fare? dove è che sbaglio? |
|
|
|
|
|
#2 | ||
|
Member
Iscritto dal: Dec 2008
Messaggi: 90
|
Quote:
OleDbCommand execute = new OleDbCommand(query_elimina, con); questo codice non basta... devi aggiungere nella riga successiva: Quote:
|
||
|
|
|
|
|
#3 |
|
Senior Member
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 |
|
|
|
|
|
#4 | |
|
Member
Iscritto dal: Dec 2008
Messaggi: 90
|
Quote:
|
|
|
|
|
|
|
#5 |
|
Senior Member
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");
}
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. |
|
|
|
|
|
#6 |
|
Senior Member
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 |
|
|
|
|
|
#7 |
|
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ò. |
|
|
|
|
|
#8 |
|
Senior Member
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 |
|
|
|
|
|
#10 | |
|
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:
|
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 09:41.




















