簡體   English   中英

如何根據特定條件動態構建 Linq 查詢

[英]How to build Linq query dynamically based on certain conditions

我有一個數據輸入表單,用戶將在其中輸入 DateFrom 和 DateTo 字段。

Select From Date: <input type="text" id="datepickerfrom" name="datepickerfrom"/>
Select To Date: <input type="text" id="datepickerto" name="datepickerto"/>
<asp:Button ID="btnGetData" runat="server" OnClick="BtnGetData_Click" Text="Get Error List" />

我想構建一個 Linq 查詢,在沒有提供輸入的情況下只檢索前 100 條記錄。

如果用戶提供了 DateFrom 而沒有提供 DateTo,則用戶將選擇大於 DateFrom 直到 DateTime.Now 的數據。

如果用戶提供了 DateTo 而沒有提供 DateFrom,則用戶將選擇小於 DateTo 的數據。

我現在有以下幾點:

public static List<ErrorLogData> GetLogErrorData(string appName, InputData data)
{
    SqlConnection con;
    List<ErrorLogData> errorLogData = null;
    string query = "";
    if (data.DateFrom == "" && data.DateTo == "")
    {
        query += "from ld in logData.errorLogs.Take(10000)";
    }

    if (data.DateFrom == "" && data.DateTo != "")
    {
        query += "from ld in logData.errorLogs where ld.errorTime <= " + data.DateTo;
    }

    if (data.DateFrom != "" && data.DateTo == "")
    {
        query += "from ld in logData.errorLogs where ld.errorTime >= " + data.DateFrom + " && <= " + DateTime.Now;
    }

    if (data.DateFrom != "" && data.DateTo != "")
    {
        query += "from ld in logData.errorLogs where ld.errorTime >= " + data.DateFrom + " && <= " + data.DateTo;
    }

    DateTime dateFrom = Convert.ToDateTime(data.DateFrom);
    DateTime dateTo = Convert.ToDateTime(data.DateTo);


    using (con = new SqlConnection(ConfigurationManager.AppSettings[conKey]))
    using (WebEntities logData = new WebEntities())
    {
        logData.CommandTimeout = 300;
        var errorLog = query + 
                       select new ErrorLogData
                       {
                           ErrorID = ld.errorID,
                           ErrorTime = ld.errorTime,
                           UserName = ld.username,
                           ErrorType = ld.errorType,
                           Error = ld.error,
                           ControlNumber = ld.controlNumber
                       };
        errorLogData = errorLog.ToList();
    }
    return errorLogData;
}

我不確定如何將query附加到“ select new ErrorLogData... ”語句以獲取整個查詢。

這里的方法是什么?

您應該能夠使用錯誤日志的 IQueryable 結果,然后為您的 if 語句執行 lambda 表達式。

            List<ErrorLogData> errorLogData = null;
        DateTime dateFrom = Convert.ToDateTime(data.DateFrom);
        DateTime dateTo = Convert.ToDateTime(data.DateTo);


        //IQueryable errorLog
        var errorLog = from ld in logData.errorLogs
                       select new ErrorLogData
                       {
                           ErrorID = ld.errorID,
                           ErrorTime = ld.errorTime,
                           UserName = ld.username,
                           ErrorType = ld.errorType,
                           Error = ld.error,
                           ControlNumber = ld.controlNumber
                       };



        if (data.DateFrom == "" && data.DateTo == "")
        {
            errorLogData = errorLog.Take(10000);
        }

        if (data.DateFrom == "" && data.DateTo != "")
        {
            errorLogData = errorLog.where(x => x.ErrorTime <= dateTo).ToList();
            //query += "from ld in logData.errorLogs where ld.errorTime <= " + data.DateTo;
        }

        //contine to implement If


        return errorLogData;

假設您正在使用某種 LINQ 數據訪問技術,請使用以下內容:

private List<Entity> GetData(DateTime? dateFrom, DateTime? dateTo)
{
    IQueryable<Entity> query = ...; //Here reference your table

    if (dateFrom == null && dateTo == null)
    {
        query = query.Take(100);
    }
    else
    {
        DateTime dateToValue = dateTo ?? DateTime.Now;

        query = query.Where(x => x.Date <= dateToValue);

        if (dateFrom != null)
        {
            query = query.Where(x => x.Date >= dateFrom.Value);
        }
    }

    return query.ToList(); //This will actually execute the query. Here you can expand your query to select specific columns before executing ToList
}

暫無
暫無

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

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