日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[Linq] Linq如何调用外部方法?

發布時間:2024/3/13 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [Linq] Linq如何调用外部方法? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Linq如何調用外部方法?

通常我們會有這樣的需求,以前寫SQL會直接在自定義函數,在EF非FECORE中處理比較麻煩。那么LINQ 能否在返回匿名實體的時直接調用外部方法呢?編譯通過,運行時報錯!
思考為何不行呢?假設方法a()
var xxxs= from…;
select new {
b=a();
}

其本質應該還是返回IQueryable或IEnumerable接口。編譯輸出xxxs.tolist()
發現是空值

思路一:匿名類型無法實現構造新列并賦值,那是否可以新建一個強類型實體并預算計算列。


遍歷賦值;

foreach (var item in fAContractNews){item.IsAttachment = IsAttachment(item.ID);item.IsContact = IsContact(item.ID);item.BudgetNoList = GetBudgetNoList(item.ID);} /// <summary>/// 是否關聯/// </summary>/// <param name="ID"></param>/// <returns></returns>private string IsContact(Guid ID){var detail = context.FAContractDetail.Where(t => t.FACID == ID);var i = detail.ToList().Count;return i > 0 ? "已錄入[" + i.ToString() + "]臺設備" : "未錄入設備";//return "未關聯任何設備";}private string GetBudgetNoList(Guid ID){string[] budgetNos = context.FAContractDetail.Where(t => t.FACID == ID).Select(a => a.BudgetNo).Distinct().ToArray(); //獲取員工編號數組 string str = string.Join(",", budgetNos);return str;}/// <summary>/// 是否有附件/// </summary>/// <param name="ID"></param>/// <returns></returns>private string IsAttachment(Guid ID){return context.MesAttachment.Any(t => t.FileId == ID) == true ? "有" : "無"; ;}

輸出仍然是空值,問題出自哪里?
還是之前同樣的問題返回的結果,并不會被修改。
所以構建一個list對象存儲之后,再遍歷;

思路二 不構建強類型實體,tolist().select()處理呢?

既然是轉成tolist()之后可以,那是否可以tolist之后.select 時調用呢?
LINQ

(from pt in db.oaProjectTaskswhere pt.ProjectID == ProjectIDjoin t in db.oaTasks on pt.TaskID equals t.TaskIDwhere t.ParentTaskID == nulllet daypassed = GetDaysPassed(t.StartDate,t.Duration)select new ChartTask{TaskNumber = t.TaskNumber,StartDate = t.StartDate,DurationRemaining = t.Duration - daypassed,TaskDescription = t.Task, DaysPassed = daypassed,Duration = t.Duration }).ToList();

自定義方法

private int GetDaysPassed(DateTime StartDate, int Duration) {int retVal;if ((DateTime.Now - StartDate).Days > 0){if ((DateTime.Now - StartDate.AddDays(Duration)).Days > 0){retVal = Duration;}else{retVal = (DateTime.Now - StartDate).Days;}}else {retVal = 0;}return retVal;}

TOLIS()后Select() Goesto 返回

(from pt in db.oaProjectTaskswhere pt.ProjectID == ProjectIDjoin t in db.oaTasks on pt.TaskID equals t.TaskIDwhere t.ParentTaskID == nullselect t).ToList() // T-SQL query will be executed here and result will be returned.Select(t => new ChartTask {TaskNumber = t.TaskNumber,StartDate = t.StartDate,DurationRemaining = t.Duration - GetDaysPassed(t.StartDate,t.Duration),TaskDescription = t.Task, DaysPassed = GetDaysPassed(t.StartDate,t.Duration),Duration = t.Duration });

因為時間關系方案二并未實際測試,理論上是可以的。

測試效果

EFCORE 調用函數:
https://docs.microsoft.com/zh-cn/ef/core/querying/user-defined-function-mapping

總結

以上是生活随笔為你收集整理的[Linq] Linq如何调用外部方法?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。