Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
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


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Crollo del mercato PC nel 2026: secondo ...
Come dimostrare che gli agenti di IA fan...
Galaxy AI potrebbe creare app funzionant...
Luce solare anche di notte con i satelli...
The Witcher 4 con ambientazioni da urlo ...
007 First Light e Control Resonant avran...
DLSS 4.5 con Dynamic Multi Frame Generat...
Meta acquisisce Moltbook, il social netw...
Red Hat al MWC 2026: attenzione all'IA n...
Amazon espande 'Paga in Contanti': ora d...
Samsung Galaxy S26 Ultra, promosso ma se...
Gemini sempre più integrato in Go...
NVIDIA investe in Thinking Machines Lab:...
NVIDIA prepara NemoClaw, piattaforma ope...
Samsung testa una batteria da 20.000 mAh...
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: 01:43.


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