从c#数据库中删除

问题描述:

我正在用VS10 express在C#WPF中编写应用程序。我不得不说我是一个非常初学者在C#和VS,但我搜索了很多谷歌的例子,我真的试图解决这个问题,我自己..从c#数据库中删除

我有一个本地数据库(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语句返回零启动,但如果我把我的数据,我得到了“独特价值的错误”。

删除它的唯一方法是从数据网格中手动删除它,然后推送一个Update按钮,它真正从数据存储中删除它。

由于开发原因,使数据库中的该字段不唯一是没有选择的。

如何在我的程序的加载中从数据存储/数据库(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; 
} 
+0

什么是数据?为什么您认为每次应用程序启动时都需要重新填充它? – 2011-06-14 10:37:41

+0

那么我是这样说的,但是我会在一种备份系统中使用它。因此,所有数据都必须删除,新的备份数据必须放在表格中。 – 2011-06-14 10:39:27

+0

你可以显示所有的代码,你如何填充数据,当你填写它......我在这里失踪smth:/ – Reniuz 2011-06-14 10:45:47

从您的其他职位,我要对你对这个数据库也就是MySQL的假设。您提到了一个通常意味着自动增量列的独特列。如果你在建立它们(比如说1-10)之后“删除”这些条目,然后尝试重新添加下一个循环中相同的1-10个条目,那么它会窒息你给这条消息。如果你从最后一个数字开始向你的表格添加数字......看看是否有帮助。

+0

那么这是我的问题,如果我删除行并添加,它会放弃一个错误。我想添加完全相同的数据,所以不能与其他数字或其他数据相加。所以,数据库中的现有数据必须被删除!但是如何? – 2011-06-14 11:15:45

+0

@Lars Boele:这听起来像是一件非常复杂的事情。通常情况下,数据是持久性的。也就是说,每次打开应用程序时,您都不会创建数据集,使用它,删除它,然后重新创建它的相同副本。如果您的客户端中已有数据,那么如果您只是要删除数据,为什么还需要将它们写入数据库? – Tim 2011-06-14 11:21:20

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

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

如果数据库本身定义了自动增量键,则在插入新行时不能提供该值,除非在后端暂时关闭自动增量。这不是一个ADO。NET问题,顺便说一句。这是100%的后端。