[Linq] Linq如何调用外部方法?
生活随笔
收集整理的這篇文章主要介紹了
[Linq] Linq如何调用外部方法?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Linq如何調用外部方法?
通常我們會有這樣的需求,以前寫SQL會直接在自定義函數,在EF非FECORE中處理比較麻煩。那么LINQ 能否在返回匿名實體的時直接調用外部方法呢?編譯通過,運行時報錯!
思考為何不行呢?假設方法a()
var xxxs= from…;
select new {
b=a();
}
其本質應該還是返回IQueryable或IEnumerable接口。編譯輸出xxxs.tolist()
發現是空值
思路一:匿名類型無法實現構造新列并賦值,那是否可以新建一個強類型實體并預算計算列。
遍歷賦值;
輸出仍然是空值,問題出自哪里?
還是之前同樣的問題返回的結果,并不會被修改。
所以構建一個list對象存儲之后,再遍歷;
思路二 不構建強類型實體,tolist().select()處理呢?
既然是轉成tolist()之后可以,那是否可以tolist之后.select 時調用呢?
LINQ
自定義方法
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如何调用外部方法?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: jks证书转为pem证书,Trusted
- 下一篇: delphi删除文本内容_文本编辑器Em