实体框架存储过程返回 null 对象

本文关键字:null 对象 返回 存储过程 框架 实体 | 更新日期: 2023-09-27 18:34:47

我有一个 ASP.NET 的MVC站点,我想显示存储过程中的一些详细信息。我之前对同一应用程序中不同页面上的其他存储过程做了完全相同的事情,并且它已经起作用,但是此存储过程调用返回一个 null 对象而不是预期值。

对存储过程的 EF 调用:

public MostRecentOrderDetail GetMostRecentOrder(int userId)
{
    var context = new myDatabaseContext();
    var paramUserId = new SqlParameter { ParameterName = "viUserId", Value = userId };
    var result = context.Database.SqlQuery<MostRecentOrderDetail>("usp#GetMostRecentOrder @viUserId", paramUserId).FirstOrDefault();
    return result;
}

在我的控制器中,我使用以下方法调用它:

MostRecentOrderDetail latestOrder = myDB.GetMostRecentOrder(CurrentUser.UserId).FirstOrDefault();

当我在 SQL Server Management Studio 中调用存储过程时,它会返回一个填充了正确值的单行表,我似乎无法让我的 ASP.NET MVC 站点看到它。

MVC 站点使用代码优先,并且 MostRecentOrderDetail 对象正确映射到存储过程的列。

*编辑

我已经按照下面的建议更新了我的代码@DanielDrews现在收到一个异常,我认为这是向前迈出的一步:

The data reader is incompatible with the specified 'MyApp.Models.MostRecentOrderDetail'. A member of the type, 'OrderTypeCode', does not have a corresponding column in the data reader with the same name. 

我相信我的模型被正确映射。

myDatabaseContext.cs

public partial class myDatabaseContext : DbContext
{
    // Database Initializer etc
    public IDbSet<MostRecentOrderDetail> MostRecentOrderDetails { get; set; }
    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        // ... Other Maps
        modelBuilder.Configurations.Add(new MostRecentOrderMap());
    }
    // GetMostRecentOrder() function from above
}

最近订单图.cs

 public class MostRecentOrderMap : EntityTypeConfiguration<MostRecentOrderDetail>
    {
        public MostRecentOrderMap()
            {    
                // Table and Column Mappings
                this.ToTable("usp#GetMostRecentOrder");
                this.Property(t => t.OrderTypeCode).HasColumnName("order_type_code");
                this.Property(t => t.OrderStatusCode).HasColumnName("order_status_code");
                this.Property(t => t.OrderReceivedDate).HasColumnName("order_received_date");
                this.Property(t => t.OrderShippedDate).HasColumnName("order_shipped_date");    
            }
    }

最近订单详情.cs

public class MostRecentOrderDetail
{
    [Key]
    public string OrderTypeCode { get; set; }
    public string OrderStatusCode { get; set; }
    public DateTime OrderReceivedDate { get; set; }
    public DateTime OrderShippedDate { get; set; }
}

存储过程本身:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[usp#GetMostRecentOrder]
         @viUserId int
AS
begin
SELECT TOP 1    o.order_type_code, 
        o.order_status_code,
        o.order_received_date, 
        o.order_shipped_date 
FROM    ORDER_TABLE o 
WHERE   o.user_id = @viUserId
end

实体框架存储过程返回 null 对象

这可能是参数 viUserId 的问题(值是否正确?(,尝试像这样初始化:

var paramUserId = new SqlParameter { ParameterName = "viUserId", Value = userId };

在我的应用程序中,我对过程的调用有点不同。翻译到你的问题应该是这样的:

var paramUserId = new SqlParameter { ParameterName = "viUserId", Value = userId };
var result = this.DbContext.Database.SqlQuery<MostRecentOrderDetail>("usp#GetMostRecentOrder @viUserId", paramUserId).FirstOrDefault();

还有最后一件事。 确保它们具有相同的类型(映射和数据库(。 这可能会导致异常

*编辑

该过程需要返回模型中的所有属性(同名(。 过程返回"order_type_code",但模型需要 OrderTypeCode。

参数代码中有拼写错误。您在"viUserId"缺失的@

UserID = new SqlParameter("@viUserId", userId);