Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
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


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...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Nintendo fa causa al governo USA per i d...
iPhone 17 256GB a 899€, MacBook Air 16/2...
C'è l'IA dietro la tua canzone pr...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
Una delle sonde europee di ESA Proba-3 h...
Un modder fa girare Linux su PS5: GTA V ...
MacBook Neo: nessuna sorpresa nei primi ...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
Oggi degli ottimi auricolari Sony con ca...
Muffa in casa? Questo deumidificatore da...
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: 09:41.


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