Hardware Upgrade Forum

Hardware Upgrade Forum (https://www.hwupgrade.it/forum/index.php)
-   Programmazione (https://www.hwupgrade.it/forum/forumdisplay.php?f=38)
-   -   [C#] "confermare" inserimento riga DataGridView (https://www.hwupgrade.it/forum/showthread.php?t=2964137)


sobrano 25-06-2022 13:22

[C#] "confermare" inserimento riga DataGridView
 
Salve spero di riuscire a spiegare bene cio che vorrei fare. Si tratta di qualcosa teoricamente piuttosto semplice ma che non riesco a fare.

ho un database .mdf che aggiorno tramite l'inserimento di righe su una datagridview (DGV). La DGV ha varie colonne come "nome", "telefono", "indirizzo" ecc.

Ho creato un bottone "salva" che serve appunto per esportare i dati dalla DataGridView al file del database.

Mentre sto aggiungendo i dati nelle varie celle di una riga della DGV (quindi mentre sto scrivendo il nome, il telefono, l'indirizzo nelle celle adatte) sulla prima cella (l'header della riga) a sinistra appare l'iconcina di una piccola matita che mi mostra che sto appunto editando una riga della DGV.

Quando ho finito di scrivere i miei dati nelle varie celle della riga, allora premo il tasto invio sulla tastiera ed il cursore si sposta sulla riga successiva, l'iconcina della matita sparisce (ad indicare che l'editing della riga e' terminato). Solo a questo punto clicco sul mio bottone "salva" e la DGV viene correttamente esportata nel file del mio database, completamente compresa la riga appena inserita.

Se invece mi dimentico di cliccare sul tasto invio una volta finito di scrivere i dati, e al contrario clicco direttamente il mio bottone "salva", allora in questo caso la nuova riga appena inserita non viene trasferita sul database.

E' come se premere il tasto invio aggiunge effettivamente questa riga alla DataGridView, la quale viene in questo caso esportata correttamente nel database. Non cliccando sul tasto invio invece, e' come se la riga rimane in stato di editing e non viene ancora effettivamente aggiunta alla datagridview per cui quando esporto la datagridview sul file del database questa nuova riga sparisce, come se non fosse mai stata inserita.

So che la pressione del tasto invio durante l'inserimento di una riga in una datagridview invoca diverse operazioni che non conosco e che evidentemente sono necessarie per confermare l'inserimento della nuova riga.

Vorrei semplicemente "confermare" in modo automatico la riga mettendo del codice dentro al mio bottone "salva", in modo che anche se mi dimentico di cliccare invio, al momento del click sul bottone salva la riga viene confermata automaticamente e correttamente esportata nel file del database.

Qualcuno puo consigliarmi quale istruzione/i dovrei aggiungere al bottone "salva" per "confermare" una nuova riga in corso di inserimento nella DGV?

grazie a tutti

antonio338 28-06-2022 21:30

Dovresti invocare il metodo EndEdit() del DataGridView prima di salvare sul database

sobrano 30-06-2022 18:24

Quote:

Originariamente inviato da antonio338 (Messaggio 47876196)
Dovresti invocare il metodo EndEdit() del DataGridView prima di salvare sul database

Salve Antonio, ho gia provato ad invocare l'EndEdit e anche il RowUpdate ma non funziona. Probabilmente la pressione del tasto enter in una datagridview fa dell'altro oltre a semplicemente chiudere la fase di editing della riga...

antonio338 02-07-2022 09:54

Immagino che tu stia usando un DataTable come DataSource del DGV... dovresti provare a metterci un BindingSource di mezzo, quindi l'ordine sarebbe DGV -> BindingSource -> DataTable (o DataSet)
E' un bel pò che non ci metto mano ma mi ricordo che risolveva parecchi problemi di questo tipo.

sobrano 03-07-2022 12:47

Quote:

Originariamente inviato da antonio338 (Messaggio 47878988)
Immagino che tu stia usando un DataTable come DataSource del DGV... dovresti provare a metterci un BindingSource di mezzo, quindi l'ordine sarebbe DGV -> BindingSource -> DataTable (o DataSet)
E' un bel pò che non ci metto mano ma mi ricordo che risolveva parecchi problemi di questo tipo.


Salve Antonio intanto grazie per le risposte.
Allora sto usando proprio l'ordine che dici. Il BindingSource in mezzo già c'è.
La DataGridView è gia associata tramite BindingSource.

Il tasto "Salva" che ho creato esegue solo 1 istruzione (questa in basso) e funziona benissimo!
Infatti inserisco i dati nelle celle di una riga della DGV poi premo enter sulla tastiera, clicco questo pulsante salva che ho creato e tutto va alla perfezione! se pero mi dimentico di premere enter, quando clicco sul tasto salva, la nuova riga viene dimenticata e non viene registrata...
Non sono un esperto ma mi sembra piu un problema al livello di DGV.
Codice:


private void salvaClientiBtn_Click(object sender, EventArgs e)
        {       
            tabellaClientiTableAdapter.Update(dataSet.TabellaClienti);     
        }


Shirov 06-07-2022 22:40

Ho memorizzato, non ricordo neanche bene il perchè, questo link tra i miei preferiti
https://stackoverflow.com/questions/...r-datagridview

non so se può essere utile o dare un qualche spunto....

sobrano 22-07-2022 06:17

Quote:

Originariamente inviato da Shirov (Messaggio 47882316)
Ho memorizzato, non ricordo neanche bene il perchè, questo link tra i miei preferiti
https://stackoverflow.com/questions/...r-datagridview

non so se può essere utile o dare un qualche spunto....

Grazie Shirov, sembrerebbe esattamente il problema che stavo cercando di risolvere, evidentemente è qualcosa che anche altri hanno riscontrato nell'uso delle DGV. Non so se ho capito bene la soluzione proposta ma vedo che riesco a combinare...


Tutti gli orari sono GMT +1. Ora sono le: 08:46.

Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Hardware Upgrade S.r.l.