gpt4 book ai didi

c# - 从 SqlDataReader 命令中选择列值

转载 作者:太空狗 更新时间:2023-10-30 00:58:54 25 4
gpt4 key购买 nike

我有一个包含两列的 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;
}

最佳答案

要从数据读取器读取列,您可以简单地在结果集中指定它的索引。因此,要从上面编写的查询中获取值,您可以这样写:

// 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);
}

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

关于c# - 从 SqlDataReader 命令中选择列值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1996912/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com