zoukankan      html  css  js  c++  java
  • EF 接收OUTPUT参数的方法 How to Retrieve Stored Procedure Output Parameters in Entity Framework

    原文地址:http://blogs.microsoft.co.il/gilf/2010/05/09/how-to-retrieve-stored-procedure-output-parameters-in-entity-framework/ 

     

    How to Retrieve Stored Procedure Output Parameters in Entity Framework

    One question that How to Retrieve Stored Procedure Output Parameters in Entity Framework
    raises from time to 
    time in EF forums 
    is how you can 
    retrieve stored 
    procedure output 
    parameters in EF 
    Function Import. 
    This post will show you how to do that.

    The Stored Procedure

    In the example I’m going to use the following stored procedure:


    CREATE PROCEDURE dbo.SchoolBudgetForDateRange
        @StartDate DATETIME,
        @EndDate DATETIME,
        @Sum money output
    AS
    SET NOCOUNT ON;
    SELECT @Sum = SUM(Department.Budget)
    FROM Department 
    WHERE StartDate BETWEEN @StartDate AND @EndDate

    The stored procedure returns the school budget for a given date. 
    By of course the stored procedure could return that calculation 
    without using an output parameter.

    Retrieving Stored Procedure Output Parameter

    After creating a Function Import (which is explained here) we can 
    use the SchoolBudgetforDateRange method with the context we have. 
    In order to get an output parameter you need to supply an ObjectParameter 
    to the stored procedure call which holds the parameter name and type. 
    After the execution of the stored procedure you can retrieve the 
    parameter using the Value property of the ObjectParameter
    The following code shows how to that exactly what I wrote:


    static void Main(string[] args)
    {
      using (SchoolEntities context = new SchoolEntities())
      {
        var outputParameter = new ObjectParameter(“sum”, typeof(decimal));
        context.SchoolBudgetForDateRange(new DateTime(2007, 1, 1), 
          new DateTime(2008, 1, 1), 
          outputParameter);
        Console.WriteLine(outputParameter.Value);
      }
    }

    Summary

    Once you need to retrieve output parameters from EF Function Imports
    you need to supply an ObjectParameter to hold the output. In the post 
    I showed how to do that.

    ----------------------------------------

    自我测试

    ALTER PROC [dbo].[usp_AddTeacherInfo]
    @Name NVARCHAR(50),
    @Phone NVARCHAR(50),
    @Address NVARCHAR(50),
    @Age INT,
    @Sum UNIQUEIDENTIFIER OUTPUT
    AS
    BEGIN
    SET NOCOUNT ON
    DECLARE @TmpID UNIQUEIDENTIFIER
    SET @TmpID = NEWID()
    INSERT INTO dbo.Teacher
    (ID, Name, Phone, Address, Age )
    VALUES ( @TmpID,@Name,@Phone,@Address,@Age)

    SET @Sum = @TmpID
    SET NOCOUNT OFF
    END

    public void AddTeacherInfo()
    {
    using (DemoDBEntities entity = new DemoDBEntities())
    {
    var outputParameter = new ObjectParameter("sum", typeof(Guid));

    var dd = entity.usp_AddTeacherInfo("dapeng", "021-99999999", "address222", 86, outputParameter);

    }
    }

  • 相关阅读:
    day04 列表和元组
    Python2和Python3的区别
    Ruby学习笔记2 : 一个简单的Ruby网站,搭建ruby环境
    Patrick Hughes
    Ruby学习笔记1 -- 基本语法和数据类型, Class
    Javascript学习笔记5
    php学习笔记1——使用phpStudy进行php运行环境搭建与测试。
    Linux配置和管理msyql命令
    干净win7要做几步才能运行第一个Spring MVC 写的动态web程序
    The difference between Spring Tool Suite and Spring IDE
  • 原文地址:https://www.cnblogs.com/niaowo/p/3621228.html
Copyright © 2011-2022 走看看