如何获得DataRow在DataTable中的行号

如题所述

第1个回答  2016-06-27
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;
}

当然,该方法最终也是能获得我们想要的行号的,只是略显复杂了.本回答被提问者和网友采纳
第2个回答  2018-01-10
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("");
}
相似回答