我有以下代码从存储过程中获取值表。我的目标是将我从存储过程中收到的表保存到某个列表或IEnumerable中以便稍后在代码中处理它。
存储过程返回两行:id和Name。代码工作正常,除非我使用它在foreach循环中写入值来测试,它只列出列名而不是值。
string cs =ConfigurationManager.ConnectionStrings["con1"].ToString();
string procName= "testing2";
SqlConnection conn=new SqlConnection(cs);
try
{
SqlDataAdapter da = new SqlDataAdapter();
da.SelectCommand = new SqlCommand(procName, conn);
da.SelectCommand.CommandType = CommandType.StoredProcedure;
DataSet ds = new DataSet();
da.Fill(ds);
ds.Tables[0].TableName = "Rows";
foreach (DataColumn c in ds.Tables[0].Columns)
{
c.ColumnMapping=MappingType.Attribute;
Console.WriteLine(c.ColumnName.ToArray());
}
}
catch (Exception e)
{
Console.Write("Error" + e);
}
finally
{
conn.Close();
}
我认为我在以下两行代码中犯了错误,这两行代码只写了列名而不是值:
c.ColumnMapping=MappingType.Attribute;
Console.WriteLine(c.ColumnName.ToArray());
有任何建议如何纠正吗?谢谢
答案 0 :(得分:0)
我相信你想要这个:
Console.WriteLine(c.ColumnName.ToArray() + ": " + c.ToNullSafeString());
答案 1 :(得分:0)
你需要循环到Rows Collection是否要打印包含单列值的ItemArray上的行值和每一行 -
foreach (DataRow r in ds.Tables[0].Rows)
{
for(int x = 0; x < r.ItemArray.Length; x++)
Console.WriteLine(r.ItemArray[x].ToString());
Console.WriteLine();
}
当然这只是一个例子。需要更强大的代码来处理空值等情况。
答案 2 :(得分:0)
您有子处理计算,因此只需传递给“DataSet ds”的子值,并在子处理它作为数据集,以获得您需要的任何值。