如何获得DataRow在DataTable中的行号
2个回答
展开全部
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;
}
当然,该方法最终也是能获得我们想要的行号的,只是略显复杂了.
示例如下:
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;
}
当然,该方法最终也是能获得我们想要的行号的,只是略显复杂了.
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
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("");
}
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("");
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询