如何获得DataRow在DataTable中的行号

 我来答
缘Lai如茨
2016-06-27 · TA获得超过8631个赞
知道大有可为答主
回答量:7534
采纳率:92%
帮助的人:610万
展开全部
IndexOf()方法说明:获取指定 System.Data.DataRow 对象的索引

示例如下:

private int FindRowIndex(DataRow dr)
{
return dr.Table.Rows.IndexOf(dr);
}

附上网上朋友的思路:
设置好DataTable的主键,然后用for(int i=0;i<DataTable.Rows.Count;i++)来循环DataTable中的每一行,逐行判断该行是否是我们查找到的行,如果是,则返回i

示例如下:

private int FindRowIndex(DataRow dr)
{
for(int i=0;i<DataTable.Rows.Count;i++)
{
if(DataTable.Rows[i]["主键列"].ToString()=="我们要查找的值")
{
return i;
}
}
return 0;
}

当然,该方法最终也是能获得我们想要的行号的,只是略显复杂了.
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
最最最最醉醉醉
2018-01-10
知道答主
回答量:1
采纳率:0%
帮助的人:909
展开全部
SqlConnection conn = new SqlConnection(strconn);
conn.Open();
SqlDataAdapter myda = new SqlDataAdapter(SqlStr, conn); // 实例化适配器
DataTable dt = new DataTable(); // 实例化数据表
myda.Fill(dt); // 保存数据
conn.Close(); // 关闭数据库连接
//符合条件的DataRow数组 LINQ难点的可能不会 这个是很简单的。
DataRow[] dataRows1 = dt.Select("编号=2");
foreach (DataRow dr in dataRows1) {
//获取改行在表中的索引
Console.WriteLine(dt.Rows.IndexOf(dr));
for (int i = 0; i <dr.ItemArray.Length; i++)
{
Console.Write(dr[i]+" " );
}
Console.WriteLine("");
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式