存储过程有效,但在 C# 中给出了无效列

Stored procedure works, but gives invalid column in c#

当我运行在 SMSS 中使用下面的存储过程时,它起作用了,returns 一个不错的结果。

SQL:

EXEC @return_value = [dbo].[xxxxxx_EnergiAllTags]
    @SegmentResponseID = 'xxxxxxxxxx'

但是当我尝试从我的 C# 代码 运行 存储过程时,我收到一个错误:

Invalid column name 'Value'

这是我的代码:

 public DataSet GetQuery(string batchNr)
 {
        SqlConnection conn = new SqlConnection("xxxxxxxx");
        SqlCommand command = new SqlCommand("xxxxxx_EnergiAllTags", conn);
        SqlDataAdapter da = new SqlDataAdapter(command);
        command.CommandType = CommandType.StoredProcedure;
        command.Parameters.Add(new SqlParameter("@SegmentResponseID", batchNr));

        DataSet ds1 = new DataSet();
        command.CommandTimeout = 60000;

        try
        {
            da.Fill(ds1);
            return ds1;
        }
        catch (Exception e)
        {
            string ex = e.Message;
            throw;
        }
    }

任何有线索的人都可以帮助我找出问题所在吗?

****根据要求更新*****

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER PROCEDURE [dbo].[xxxxxx_EnergiAllTags]
    @SegmentResponseID AS VARCHAR(MAX)
AS
BEGIN
    SET NOCOUNT ON;

    CREATE TABLE #temp (TagName NVARCHAR(MAX),
                        StartValue NVARCHAR(MAX),
                        EndValue NVARCHAR(MAX),
                        Usage NVARCHAR(MAX)
                       )

    INSERT INTO #temp 
        EXEC [dbo].[xxxxxx_EnergyTagForBatch] @BatchID = @SegmentResponseID, 
@TagName = 'T06C02D01E02FQ000.PV'

    INSERT INTO #temp 
        EXEC [dbo].[xxxxxx_EnergyTagForBatch] @BatchID = @SegmentResponseID, 
@TagName = 'T06C02D01E02FQ001.PV'

    SELECT * From #temp
    DROP TABLE #temp
END

好的,我已经找到问题了。

我的 2 个 SP 都有一个名为 #temp 的临时 table,虽然我认为它们应该本地化到每个实例,但它们并没有本地化,而且是混合的,到那时他们给出了一个错误。

解决办法,确保在你可能调用的存储过程字符串中没有使用同名的temp tables。