gpt4 book ai didi

c# - 如何通过 LINQ to SQL 返回可变列长度

转载 作者:太空狗 更新时间:2023-10-29 23:09:40 26 4
gpt4 key购买 nike

我在 Internet 上进行了搜索,但找不到任何与我所寻找的直接匹配的东西......

我有一个存储过程,它返回一组固定的列(比如 ColumnA、ColumnB 和 ColumnC),然后另外返回一个不确定的数字/附加列的签名(可能是 ColumnD、ColumnE 和 ColumnF,或者 ColumnF、ColumnP、ColumnT和 ColumnW)。

查询的动态部分由过程的 Id 参数决定。

不幸的是,我无法控制模式,而且它的设计很糟糕,在末尾添加了大量不相关的列(并且他们不断添加它们),而不是有一个额外的表来存储这很有效。

因此,我无法在编译时返回一组确定的列,因此 LINQ to SQL 无法确定存储过程的返回类型。

我还有其他选择或方法可以解决这个问题吗?下面是我正在做的一个例子。我可以重写它以使用 LINQ to SQL 吗?如果有帮助,我正在使用 C# 和 SQL Server 2008 编写应用程序。

谢谢。

CREATE PROCEDURE [Foo].[GetBar]
(
@Id INT,
@FooVar VARCHAR(50),
@BarVar DATE
)

AS
BEGIN

CREATE TABLE #TempTbl
(
[ColumnName] VARCHAR(50)
)

INSERT #TempTbl EXEC [Foo].GetColumnNames @Id
DECLARE @ColumnNameList NVARCHAR(max)
SET @ColumnNameList = ''
SELECT @ColumnNameList = COALESCE(@ColumnNameList + '],[', '') + ColumnName FROM #TempTbl
DROP TABLE #TempTbl
SELECT @ColumnNameList = @ColumnNameList + ']'
SELECT @ColumnNameList = SUBSTRING(@ColumnNameList, 3, LEN(@ColumnNameList) )

DECLARE @FixedColumns VARCHAR(200)
DECLARE @SelectQuery NVARCHAR(max)
DECLARE @WhereQuery VARCHAR (100)
DECLARE @FullQuery NVARCHAR(max)
DECLARE @ParamaterDef nvarchar (100)
DECLARE @Foo VARCHAR(50)
DECLARE @Bar DATE

SET @FixedColumns = N'[ColumnA], [ColumnB], [ColumnC], '
SET @SelectQuery = N'SELECT ' + @FixedColumns + @ColumnNameList + N' FROM [Foo].[FooBar] '
SET @WhereQuery = N'WHERE [Foo] = @Foo AND [Bar] = @Bar'
SET @FullQuery = @SelectQuery + @WhereQuery
SET @ParamaterDef = N'@Foo VARCHAR(50), @Bar DATE'

EXECUTE sp_executesql @FullQuery, @ParamaterDef, @Foo = @FooVar, @Bar = @BarVar

END

最佳答案

您不能只使用填充DataSetSQL 数据适配器 吗?然后,您可以使用 LINQ 到 DataSet 并执行所有 LINQ 操作:

DataTable yourDataTable = ds.Tables["TableName"];

var query =
from yourDataTable in yourDataTable.AsEnumerable()
select new
{
NewField = yourDataTable.Field<int>("ColumnName"),
NewField2 = yourDataTable.Field<string>("ColumnName2"),
};

MSDN (LINQ to DataSet)

MSDN (Single table queries using LINQ to DataSet

关于c# - 如何通过 LINQ to SQL 返回可变列长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10795694/

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