【发布时间】: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