保存列表中存储过程的表输出值

时间:2013-06-13 16:45:15

标签: c# .net sql-server tsql

我有以下代码从存储过程中获取值表。我的目标是将我从存储过程中收到的表保存到某个列表或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());

有任何建议如何纠正吗?谢谢

3 个答案:

答案 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”的子值,并在子处理它作为数据集,以获得您需要的任何值。