Veröffentlicht 26. September 200816 j Hi Ich arbeite an einem Programm, wo auf Knopfdruck eine DataTable in einem DataSet befüllt wird, je eine Zeile. Und diese DataTable wird mir auf der Form in einer DataGridView angezeigt. private void ButtonAdd_Click(object sender, EventArgs e) { Int32 iMenge; Double dPreis, dGesamtPreis, dRabatt; String StrService; iMenge = Int32.Parse(TextBoxMenge.Text); if (iMenge > 0) { iPositionen += 1; StrService = Kategorie + " - " + TextBoxService.Text; dRabatt = double.Parse(TextBoxRabatt.Text.ToString()); dPreis = Double.Parse(TextBoxPreis.Text.Replace("€", " ")); if (TextBoxStrecke.Text != "") { iMenge = Int32.Parse(TextBoxStrecke.Text.ToString() ); StrService += " (" + TextBoxStrecke.Text.ToString() + ")km"; } dPreis -= dPreis * (dRabatt / 100); Math.Round(dPreis, 2); dGesamtPreis = dPreis * iMenge; dataSet1.Tables["dtPositionen"].Rows.Add(iPositionen, StrService, iMenge, dPreis.ToString("C"), dGesamtPreis.ToString("C")); DataGridViewPos.Rows.Add(dataSet1.Tables["dtPositionen"].Rows[iPositionen - 1].ItemArray); if (iPositionen > 4) { DataGridViewPos.Columns["TBCService"].Width = 583; } DataGridViewPos.Update(); } } private void button3_Click(object sender, EventArgs e) { Int32 anzahl = dataSet1.Tables["dtPositionen"].Rows.Count; MessageBox.Show(anzahl.ToString()); for (Int32 i = 0; i<=anzahl ; i++) { //dataSet1.Tables["dtPositionen"].Rows.RemoveAt(anzahl - i); //dataSet1.Tables["dtPositionen"].DataSet.Tables["dtPositionen"].Rows.Clear(); //dataSet1.Tables["dtPositionen"].Rows[0].Delete(); //dataSet1.Tables["dtPositionen"].Rows.Clear(); dataTable1.Rows.Clear(); } ControlsBefuellen(1, 0, 0,0,""); iPositionen = 0; } Das Füllen der DataTable, sowie des GridViews funktioniert. bei der letzten Methode von mir soll der komplette Inhalt der DataTable gelöscht werden, was auch soweit funktioniert. ich bekomme beim 2. mal Drücken des Buttons die Message "0" also 0 Datensätze in der Table. Aber meine GridView zeigt mir immernoch alles an was jemals in der Table war und wenn ich nun wieder neue Datensätze in die Table schreibe nach dem 1. löschen added er die auch in die GridView. Nur das öschen funktioniert nicht ganz. Weis jemand woran das liegt?! Liebe Grüße Basti
28. September 200816 j Hi, du rufst Clear auf das falsche Objekt auf (dataTable1 anstelle der Tabelle des Datasets. Zudem ist die for-schleife falsch, ein Aufruf von Clear reicht.
28. September 200816 j Hallo danke für deine Antwort. Die Schleide war auch mehr zu Testzwecken. Habe ja mehrere Möglichkeiten getestet wie ich die Tabelle nun leerbekomme. Liebe Grüße Basti
Archiv
Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.