在c#中从数据库中删除

时间:2011-06-14 10:31:22

标签: c# sql wpf database

我正在使用VS10 express在C#WPF中编写应用程序。 我不得不说我是C#和VS的初学者,但是我在Google上搜索了很多例子,我真的试图自己解决这个问题..

我有一个本地数据库(mydatabase.sdf),在我的窗口加载时,我用一些数据填充该数据库的表。该表的一个字段需要一个唯一的值,所以我想在每个加载中输入相同的数据,但是我得到的错误比当然要多。

我想在重新填充之前删除数据库中的所有数据,这似乎很容易,但我没有让它工作......

我试过

dataset.Tables["mytable"].Clear()

不起作用,它似乎只是从datagrid(dataTable)中删除数据,而不是从数据存储中删除。

我也尝试过:

for (int i = 0; i < dataset.Tables["mytable"].Rows.Count; i++)
{
  dataset.Tables["mytable"].Rows[i].Delete();
}
  this.TableAdapter.Update(this.dataset);

但是在启动时dataset.Tables["mytable"].Rows.Count语句在启动时返回零,但是如果我输入我的数据,我会得到“唯一值错误”。

删除它的唯一方法是从数据网格中手动删除它,然后按下一个更新按钮,它真正将其从数据存储中删除。

由于开发原因,不能在数据库中使该字段不唯一。

如何在程序加载中从数据存储区/数据库(mydatabase.sdf)中删除真正的数据?

修改

以下是我用数据填充数据库的代码:

public void FillInternet()
    {
        klantenTableAdapter1.ClearBeforeFill = false;


        string MyConString =    "SERVER=myserver;" +
                                "DATABASE=mydb;" +
                                "UID=myuid;" +
                                "PASSWORD=mypass;";

        MySqlConnection connection = new MySqlConnection(MyConString);
        MySqlCommand command = connection.CreateCommand();
        MySqlDataReader Reader;
        command.CommandText = "SELECT klantnr, voorletters, roepnaam, achternaam, tussenvoegsel, meisjesnaam, straat, huisnr, subhuisnr, postcode, plaats, telthuis, telmobiel, telwerk, fax, email, geboortedatum FROM klanten ORDER BY klantnr";
        connection.Open();
        Reader = command.ExecuteReader();


        try
        {
            while (Reader.Read())
            {
                DataRow newLogRow = dataset1.Tables["klanten"].NewRow();
                var thisrow = "";

                for (int i = 0; i < Reader.FieldCount; i++)
                {
                    thisrow = Reader.GetValue(i).ToString();
                    newLogRow[Reader.GetName(i)] = thisrow;
                }

                dataset1.Tables["klanten"].Rows.Add(newLogRow);
                this.klantenTableAdapter1.Update(this.dataset1);
            }
            connection.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show("Error: " + ex.Message,"Fout",MessageBoxButton.OK,MessageBoxImage.Error);
        }

        dataset1.AcceptChanges();

        //Fill from internet
        //da.Fill(dataset1.klanten);

        //Fill from local database
        klantenTableAdapter1.Fill(dataset1.klanten);

        this.klantenTableAdapter1.Update(this.dataset1);

        this.DataContext = dataset1.klanten.DefaultView;
}

2 个答案:

答案 0 :(得分:3)

ADO.NET使用“断开连接”的记录集模型。它在客户端结构(DataSet和DataTable)中保留数据的副本。需要将对客户端结构所做的更新/插入/删除推送回数据库。您需要阅读ADO.NET以获得对此过程的基本了解,并了解ADO.NET事件模型,如果您想要执行任何涉及典型现实复杂情况的事情,这将是必要的。在ADO.NET上写了很多书,因为它是一个功能丰富的中间层数据层,具有很大的复杂性。

出于您的目的,您可以阅读ADO.NET Command对象和SQL“delete”命令。您还需要了解ADO.NET如何处理自动增量主键,这是断开连接模型中最棘手的方面之一。

如果数据库本身定义了自动增量键,则在插入新行时无法提供该值,除非您在后端暂时关闭自动增量。这不是ADO.NET问题,BTW。这是100%的后端。

答案 1 :(得分:0)

在你的其他帖子中,我假设你的数据库也是MySQL。您提到了一个唯一的列,通常表示自动增量列。如果你在构建它们之后“删除”这些条目(例如从1-10开始),然后尝试重新添加下一个循环相同的1-10个项目,它就会阻止你给你这个消息。如果您从最后使用的数字开始向表中添加数字...看看是否有帮助。