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
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.
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
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden