【问题标题】:Select Column values from SqlDataReader command从 SqlDataReader 命令中选择列值
【发布时间】:2010-01-04 00:28:37
【问题描述】:

我有一个表,其中包含要从中提取值的 SQL 中的两列。但问题是我不知道如何在 C# 代码中检索第 2 列的值。我正在使用 SQL Server 2008 和 VS。我必须在 SP 中使用 OUTPUT 参数吗?如果是这样,我将如何指定此 SP?我已经尝试了 OUTPUT 参数,但我无法创建没有错误的 OUTPUT 参数,因为我也在尝试选择 COLUMN_NAME。此查询返回 4 列,我也只想获取此列数。应该有一个更简单的方法来做到这一点,不是吗?这适用于 SQL,但不适用于 C#。

这是我的 SP:

CREATE PROCEDURE [dbo].[getColumnNames]
    @TableName varchar(25) 
AS
    SELECT name 'COLUMN_NAME', (
         SELECT COUNT(ID)
         FROM syscolumns WHERE id = (
             SELECT id
             FROM sysobjects
             WHERE name= @TableName)) 'ROW_COUNT'
    FROM syscolumns
    WHERE id = (SELECT id FROM sysobjects WHERE name= @TableName)
    RETURN

这是我调用此 SP 的 C# 代码:

public static SqlDataReader DisplayTableColumns(string tt)
{
    SqlDataReader dr = null;
    string TableName = tt;
    string connString = "Data Source=.;AttachDbFilename=\"C:\\Program Files\\Microsoft SQL Server\\...";
    string errorMsg;

    try
    {
        SqlConnection conn2 = new SqlConnection(connString);
        SqlCommand cmd = conn2.CreateCommand();
        cmd.CommandText = "dbo.getColumnNames";
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Connection = conn2;
        cmd.Parameters.Add(new SqlParameter("@TableName", TableName));
        conn2.Open();
        dr = cmd.ExecuteReader();
    }
    catch (Exception ex)
    {
        errorMsg = ex.Message;
    }
    return dr;
}

【问题讨论】:

  • 看起来你拥有的是一个从给定表中提取列名的存储过程。相反,您是否尝试从该表中提取列值?如果是这样,您是否有可用的表模式?这样更容易充分回答您的问题。
  • @TableName 参数包含我要从中检索列名的表的名称。所以我试图从@TableName 表中获取列值。这就是我称之为列名的原因,因为我从这个表中得到的列值实际上是列名。有道理?我不确定你所说的表模式是什么意思。你有什么推荐?我也在尝试获取总列数。
  • 澄清一下,如果您使用上面的代码,您将不会从列中获取值,您只会获取列名。如果这不是你想要的,你需要以不同的方式做事
  • 我不确定你的意思,迈克尔。我的列值是列名。请参阅我上面的评论以获得对此的解释。
  • 啊。知道了。只要确保你知道你得到的 values 实际上是列名。

标签: c# sql sqldatareader


【解决方案1】:

要从数据读取器读取列,您只需在结果集中指定其索引即可。因此,要从您上面编写的查询中获取值,您可以编写:

// straight after this line:
dr = cmd.ExecuteReader();

if (dr.Read()) // you only have one row so you can use "if" instead of "while"
{
    var columnName = dr.GetString(0);
    var rowCount = dr.GetInt32(1);
}

编辑糟糕!你需要先阅读。我已经更新了代码。

【讨论】:

  • 我之前尝试过,但是我得到了以下异常: + dr.GetString(0) 'dr.GetString(0)' throwed an exception of type 'System.InvalidOperationException' string {System.InvalidOperationException }
  • 不,我实际上应该有不止一行,因为每个表列应该有一行,所以总共有四行。我应该把它改成“一会儿”吗?
  • 我试过这个,但它抛出了一个异常:- base {“当没有数据存在时读取无效。”} System.SystemException {System.InvalidOperationException} 并且:- dr[0] 'dr [0]' 抛出类型为 'System.InvalidOperationException' 的异常对象 {System.InvalidOperationException} 这是我添加到 DisplayTableColumns 方法中的代码,就在最后的“return dr”语句之前:while (dr.Read()) { 字符串 ocn = dr.GetString(0); int nr = dr.GetInt32(1); }
  • 我在这里遇到问题:stackoverflow.com/questions/23939164/…。请帮忙
猜你喜欢
  • 2013-08-25
  • 1970-01-01
  • 1970-01-01
  • 2021-12-16
  • 2018-07-08
  • 2021-11-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多