1

我正在使用 LINQ 和 DataContext 来检索我的数据。我不使用实体框架。现在我有一个我不知道的存储过程

  1. 如何提供参数和
  2. 如何定义(单个值)并从中获取结果。

存储过程是这样定义的:

CREATE PROCEDURE [dbo].[spGetConvertedFieldValue] 
-- Add the parameters for the stored procedure here
    @Table NVARCHAR(50),
    @Field NVARCHAR(50),
    @Key NVARCHAR(50),
    @KeyValue NVARCHAR(500)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;

    DECLARE @SQL NVARCHAR(MAX)

    SET @SQL = 'SELECT ' + @Field + ' FROM ' + @Table + ' WHERE ' + @Key + ' = ''' + @KeyValue + ''''

EXEC(@SQL)
END

如您所见,这是一个非常通用的存储过程!这样做的原因是,我有另一个表,可以在其中输入上述值,系统将能够构建我的最终结果。

但我这里有点存货。我已阅读文章:http ://www.codeproject.com/Articles/37938/Simple-6-steps-to-use-stored-procedure-in-LINQ ,其中指定了如何调用存储过程。但有一件事是,我似乎至少应该能够定义我指的是哪个表(步骤 2)

此外,上面的文章没有描述如何添加我的论点。

如果可以通过不使用存储过程来创建结果,那也是一种选择!

4

1 回答 1

0

好的,这是解决方法:

首先,我创建一个名为 TemporaryParking 的新表:

CREATE TABLE [dbo].[TemporaryParking](
[Id] [int] IDENTITY(1,1) NOT NULL,
[Field] [nvarchar](max) NULL,
 CONSTRAINT [PK_TemporaryParking] PRIMARY KEY CLUSTERED 
(
    [Id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  =     ON, ALLOW_PAGE_LOCKS  = ON, FILLFACTOR = 10) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO

接下来我创建一个存储过程,它可以填充我的表并返回新插入值的 id:

CREATE PROCEDURE [dbo].[spGetConvertedFieldValue] 
-- Add the parameters for the stored procedure here
@Table NVARCHAR(50),
@Field NVARCHAR(50),
@Key NVARCHAR(50),
@KeyValue NVARCHAR(500)
AS
BEGIN
SET NOCOUNT ON;

DECLARE @SQL NVARCHAR(MAX)

SET @SQL = 'INSERT INTO TemporaryParking (Field) SELECT ' + @Field + ' FROM ' + @Table + ' WHERE ' + @Key + ' = ''' + @KeyValue + ''''

EXEC(@SQL)

RETURN @@Identity   
END

在我的应用程序中,我创建了一个“包含”我的存储过程 spGetConvertedFieldValue 的 .dbml 文件。

调用此过程时,它将从插入的值返回 Id,然后我可以创建一个简单的 LINQ 语句来获取值:

'lets assume that I now have the Id in a variable calle tmpId

var rv = (from f in _db.TemporaryParking
         where f.Id == tmpId
         select f.Field).First();

如果我愿意,我什至可以通过再次删除 TemporaryParking 中的值来进行清理。

感谢 Thorsten Dittmar 为我指明了正确的方向!不过,您的回答并没有起到全部作用。

于 2013-09-24T08:07:30.293 回答