如何删除dataset中的某行数据和添加多组数据

stringdbPath=@"D:\历年高考分数.db";stringsq=@"DataSource="+dbPath;m=newSQLiteConnection(sq)... string dbPath = @"D:\历年高考分数.db";
string sq = @"Data Source=" + dbPath;
m = new SQLiteConnection(sq);
m.Open();
SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select Volume1,Volume2 from 曲线", m);
DataSet ds = new DataSet();
mAdapter.Fill(ds);
DataTable dt = ds.Tables[0];
if (Flag == 4)
{
SQLiteCommandBuilder cmdb = new SQLiteCommandBuilder(mAdapter);
ds.Tables[0].Rows[0].Delete();
//DataSet.AcceptChanges();
mAdapter.DeleteCommand = cmdb.GetDeleteCommand();
mAdapter.Update(ds);
}

if (Flag == 3)
{
DataRow MyRow = dt.NewRow();
MyRow["Volume1"]= textBox1.Text;
MyRow["Volume2"]= textBox2.Text;
dt.Rows.Add(MyRow);
SQLiteCommandBuilder mySqlCommandBuilder = new SQLiteCommandBuilder(mAdapter);
mAdapter.Update(ds);
}
//设置图表的数据源
Chart1.DataSource = dt;
private void button2_Click(object sender, EventArgs e)
{
Flag = 3;
}

private void button3_Click(object sender, EventArgs e)
{
Flag = 4;
}
光添加一组数据没什么问题,如何添加多组数据?
还有就是删除某行数据,会提示对于不返回任何键列信息的 SelectCommand,不支持 DeleteCommand 的动态 SQL 生成。
如何处理
展开
 我来答
HysoundACC
2019-10-14 · TA获得超过1335个赞
知道小有建树答主
回答量:1135
采纳率:60%
帮助的人:63万
展开全部
我们据。首先我们需要打开一个联结,我们的数据库还是用上一节的吧:)string MyConnString = "Driver={Microsoft Access Driver (*.mdb)}; DBQ=c:/test/test.mdb;";string strComm = "select * from UserList";ADOConnection MyConnection = new ADOConnection(MyConnString);ADODataSetCommand MyComm = new ADODataSetCommand(strComm,MyConnection);这里我们为了讲解方便,只在DataSet存入一个表的内容:DataSet MyDataSet = new DataSet();MyComm.FillDataSet(MyDataSet,"UserList");此时我们就获得了一个拥有UserList表数据的DataSet。在讲解DataSet之前,我们还需要了解DataSet的结构下面是DataSet的结构树DataSet RelationsCollectionExtendedPropertiesTablesCollection DataTables RowsColumns其它由于我们研究的是DataTable,其它的我们暂时不管他们。一个DataSet中包含多个DataTable,一个DataTable又包含有多个Row,这就是我们操作DataSet的基础啦:)添加数据添加一数据,从上面的列表中我们可以看出,其实就是添加一行Row,这里我们也来演示一下如何添加一行数据,我们程序一切以DataSet为顶点,呵呵,如果TablesCollection,RowsCollection下去的话,还有一些烦人的dt.AcceptChanges这些方法的调用,很烦人,还是一次搞定吧。DataRow dr=MyDataSet.Tables["UserList"].NewRow();dr["UserName"] = "周讯";dr["ReMark"] = "100";dr["Comment"] = "漂亮MM";MyDataSet.Tables.Rows.Add(dr);第一行,我们建立一个新的数据行,它用来储存我们新加入的数据。然后我们在这个数据行中加入我们需要的数据。dr["UserName"]表明是对UserName字段进行添加,你可以使用dr[1]来添加信息,但是这需要我们事先知道字段在数据表的位置,而且在不知道数据表结构的情况很难知道我们添加的数据的对应情况,所以还是用字段名为好。最后我们使用RowsCollection的Add方法,将我们新建这一行加入到数据表中。修改数据知道如何添加数据后,修改数据也是很简单的事情了.MyDataSet.Tables["UserList"].Rows[0]["UserName"]="飞刀大哥";这样我们就修改了第一行数据中的UserName字段。删除数据删除数据,主要是使用RowsCollection提供的Delete方法,看下面的程序也是很简单的事情啦:)MyDataSet.Tables["UserList"],Rows[0].Delete();这一行数据就已经被删除了。恢复数据有时候我们添加/修改数据会出现错误,这时候,就需要恢复原来的数据。下面的程序,显示如何判断是否有错误发生:if(MyDataSet.HasErrors){MyDataSet.RejectChanges();} 首先我们检查DataSet中是否有错误发生,如果有就使用RejectChanges()方法,恢复DataSet中的数据。注意这里恢复是在DataSet中所有表以及表中DataRow中的数据,也就是在此交次操作的数据全部恢复。如果我们只需要恢复部分内容,我们可以使用DataTable或DataRow的RejectChanges(),这里就不详细讲解了,使用方法和DataSet一样,只是操作的对像不同而已。探测DataSet是否有改动我们在将DataSet送交给数据库去保存去,我们需要看看这个DataSet是否已经被改动了。如果没有改动,我们也就没有必要去修改数据库了。if(MyDataSet.HasChanges){//保存}else{//不进行任何操作}更新数据库我们上面的操作,都只是针对DataSet的,没有操作数据库,但是我们的目的还是要将数据保存到数据中去,所以我们这里就需要调用DataSetCommand的Update方法。下面的程序显示如何将DataSet的数据交给数据库。MyComm.Update(MyDataSet);很简单的一句,呵呵。这里要注意,如果一个DataSet中包含有多个表,而我们只更新一个,那我们就必须写明更新的数据表名:MyComm.Update(MyDataSet,"UserList");当Update方法被调用后,DataSetCommand会将数据库中的数据与DataSet中的数据相比较,对不相同的地方进行更新。对于DataSet的操作,我们这里只讲这么多,其实DataSet的方法和属性有很多,功能也很全,我想现在这里的所讲的功能,对一般的操作已经足够了。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式