zoukankan      html  css  js  c++  java
  • C#中使用EntityFramework(EF)生成实体进行存储过程的调用

    在EF中使用定义对象模型的方式调用一个存储过程,这个存储过程返回的是一组包含两列的值。(ProjectName,Count)

    下面是存储过程:

    CREATE procedure [dbo].[Pro_Project_By_UserID]
        @userID nvarchar(36)
    AS
    SELECT Project AS ProjectTypeName,
     Count(BA.ProjectId) AS ProjectCount
    FROM dbo.B_AllProjectInfo BA
    WHERE IsComplex = 1
    AND UserId = @userID

    GROUP BY Project


    在DB中定义了这个SP后,在C#中的*.edmx中,选择‘从数据库更新模型’,更新方式和更新表一样。这样在C#中就会生成

    Pro_Project_By_UserID_Result

    的类,还有一个函数

            public virtual ObjectResult<Pro_Project_By_UserID_Result> Pro_Project_By_UserID(string userID)
            {
                var userIDParameter = userID != null ?
                    new ObjectParameter("userID", userID) :
                    new ObjectParameter("userID", typeof(string));
        
                return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<Pro_Project_By_UserID_Result>("Pro_Project_By_UserID_UserID", userIDParameter);
            }


    在实际执行时,代码如下:

    var curProjects = dataContext.Pro_Project_By_UserID(myUserID).ToList();

    要加上ToList(),否则返回的值不能用

  • 相关阅读:
    localhost和本机IP和127.0.0.1之间的区别
    git客户端msysGit和TortoiseGit使用
    JS正则
    css中外边距
    css定位浮动总结
    Teleport Ultra 抓包工具
    编程实践心得与设计思想
    Java 读写Properties配置文件
    如何成为一个优秀的DBA
    对DB2常见错误的列举以及破解方案
  • 原文地址:https://www.cnblogs.com/Fooo/p/10373555.html
Copyright © 2011-2022 走看看