簡體   English   中英

如何在Entity Framework 4中處理ObjectResult

[英]How to handle ObjectResult in Entity Framework 4

在Entity Framework 4中,當我使用函數import導入存儲過程然后使用標量值時,我遇到了問題。 它生成以下代碼:

public virtual ObjectResult<Nullable<int>> GetTopEmployee()
{
    return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<Nullable<int>("GetTopEmployee");
}

如何使用此方法的返回值?

例如,此代碼工作正常:

NorthwindEntities db = new NorthwindEntities();
var i = db.GetTopEmployee();

但我想僅將返回值用作int。 如果我在函數import中使用返回值為非,則將-1作為輸出。

當我嘗試下面的代碼時:

NorthwindEntities db2 = new NorthwindEntities();
int j = db.GetTopEmployee();

它拋出一個錯誤說:

無法將類型'System.Data.Objects.ObjectResult'隱式轉換為'int'

我如何解析上面的內容?

請注意, GetTopEmployee的返回類型是ObjectResult<Nullable<int>> ObjectResult<T>實現IEnumerable<T>因此您的方法能夠返回多個Nullable<int>

我假設您正在嘗試為員工獲取某種形式的Id。 如果您完全確定只獲得一個結果,則可以使用以下代碼來獲取該ID。

  var topId = db.GetTopEmployee().FirstOrDefault();

topId可能為null。 你將不得不使用topId.Valuevar result = topId ?? -1; var result = topId ?? -1; 得到一個int結果。

  NorthwindEntities db = new NorthwindEntities();
  int j = db.GetTopEmployee().FirstOrDefault() ?? -1;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM