我正在使用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;
}
答案 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个项目,它就会阻止你给你这个消息。如果您从最后使用的数字开始向表中添加数字...看看是否有帮助。