C# datatable 表复制的问题

目的:提取dataGridView1表格被修改前的值。做法{...da.SelectCommand=cmd;conn.Open();da.Fill(tbl);dataGr... 目的:提取dataGridView1表格被修改前的值。
做法

{...
da.SelectCommand = cmd;
conn.Open();
da.Fill(tbl);
dataGridView1.DataSource = tbl;
conn.Close();//转到返回键关闭;
tbl2 = tbl.Copy(); //在这里保存一张表,之前的表
....}
{...
int a = dataGridView1.CurrentCell.RowIndex; //a为该修改位置的行数,用来确认值
if ((tbl2.Rows[a]["课程名称"]).ToString() == 首页.row00 && (tbl.Rows[a]["课程名称"]).ToString() != 首页.row00) //之前为一个值,修改后不是这值
{
}

if ((tbl2.Rows[a]["学生姓名"]).ToString() == 首页.row10 && (tbl.Rows[a]["学生姓名"]).ToString() != 首页.row10) // //之前不是这值,修改是这值
{
}
.....}

报错:

(tbl2.Rows[a]["学生姓名"]).ToString() //名称
“tbl2.Rows[a]”引发了“System.IndexOutOfRangeException”类型的异常 string //显示

System.IndexOutOfRangeException:在位置0处没有任何行 //ex.Text
tbl和tbl2都是DataTable而不是DataSet
展开
 我来答
咖啡嘤0o
推荐于2016-02-14 · TA获得超过144个赞
知道小有建树答主
回答量:161
采纳率:0%
帮助的人:141万
展开全部
tbl2.Rows[a].ItemArray[tbl2.Columns.IndexOf("学生姓名")].ToString();
要获得相应列要这么写
追问
其实我的是对的,前面的模块少了点东西,导致tbl2为空表。
还是谢谢哈
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式