SebastianS Geschrieben 26. September 2008 Geschrieben 26. September 2008 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 Zitieren
Argbeil Geschrieben 28. September 2008 Geschrieben 28. September 2008 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. Zitieren
SebastianS Geschrieben 28. September 2008 Autor Geschrieben 28. September 2008 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 Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.