簡體   English   中英

Linq SQL 和 Select MAX 子查詢

[英]Linq SQL with Select MAX Sub Query

我有以下 SQL 查詢,它有一個子查詢,因此結果集中只有最大值:

Select 
t.ID,
r.ResultIdentifier,
p.ProductID,
r.Status,
r.Start
from Result r , Transact t, Product p
WHERE r.ResultIdentifier =  (Select MAX(r2.ResultIdentifier) from Result r2 
                            where r2.Status = 'Fail'
                            and r2.ID = r.ID
                            and r2.Start >= getdate() - 30)

and r.ID = t.ID
and p.productID = 9
and t.productID = p.productID

我正在嘗試將其轉換為 LINQ 查詢

var failures = from result in db.Results
               join transact in db.Transacts on result.ID equals transact.ID
               join product in db.Products on transact.ProductID equals product.ProductID
               where result.ResultIdentifier == ??
               .....
               select new{ ID = transact.ID,
               ...etc

我真的在努力解決 LINQ 中的最大 ResultIdentifier - 嘗試了 .MAX() 的多種變體,但似乎無法正確處理。歡迎提出任何建議。

您可以使用 max 關鍵字,很抱歉使用方法語法,因為我可以看到您正在使用查詢:(

應該看起來像下面這樣

where result.ResultIdentifier == (Results.Max().Where(x => x.Status.equals("Fail") && x.id == result.id && x.start => Datetime.Now().Add(-30)).Select(x => x.ResultIdentifier))

嘗試以下查詢:

var results = db.Results;
var failedResults = results
    .Where(r => r.Status == "Fail" && r.Start >= DataTime.Date.AddDays(-30));

var failures = 
    from result in results
    join transact in db.Transacts on result.ID equals transact.ID
    join product in db.Products on transact.ProductID equals product.ProductID
    from failed in failedResults
        .Where(failed => failed.ID == result.ID)
        .OrderByDescending(failed => failed.ResultIdentifier)
        .Take(1)
    where result.ResultIdentifier == failed.ResultIdentifier
    .....
    select new{ ID = transact.ID,
    ...etc

暫無
暫無

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

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