Lambda Expressions表達式使用

来源:http://www.cnblogs.com/nee32/archive/2016/09/18/5880511.html
-Advertisement-
Play Games

很多時候我們在使用Lambda表達式查詢時,比如使用Lambda表達式查詢用戶數據,有時候會用電話或郵箱去查詢用戶信息,有時候又會用戶名去查詢用戶信息 其實查詢的結果都一樣,但唯一的區別就是Lambda表達式中的條件不一樣,那麼能不能只寫一個查詢方法,而實現Lambda表達式中Where的有查詢條件 ...


很多時候我們在使用Lambda表達式查詢時,比如使用Lambda表達式查詢用戶數據,有時候會用電話或郵箱去查詢用戶信息,有時候又會用戶名去查詢用戶信息

    var user = db.Set<U_User>().Where(c => c.UserName = "nee32");
    var user = db.Set<U_User>().Where(c => c.TelePhone = "13888888888");

其實查詢的結果都一樣,但唯一的區別就是Lambda表達式中的條件不一樣,那麼能不能只寫一個查詢方法,而實現Lambda表達式中Where的有查詢條件呢?答案當然是 能!例如在三層架構中使用一個方法滿足使用多個條件查詢,代碼如下

    public class UserDAL
    {
        /// <summary>
        /// 根據條件查找用戶列表
        /// </summary>
        /// <param name="where"></param>
        /// <returns></returns>
        public List<U_User> FindAll(System.Linq.Expressions.Func<U_User, bool>> where = null)
        {
            using (EFContext db = new EFContext())
            {
                if (where == null)
                    return db.U_User.ToList();
                else
                    return db.U_User.Where(where).ToList();
            }
        }
    }

聲明瞭一個FindAll方法,參數是可空的Lambda表達式(Expression<Func<U_User, bool>>表示一個Lambda表達式)

其中Func<U_User, bool>使用泛型委托 傳入U_User,返回一個bool值

方法調用

        public ActionResult Index()
        {
            //List<U_User> userList = userBLL.FindAll(c => c.UserName == "nee32");
            //List<U_User> userList = userBLL.FindAll(c => c.UserName == "nee32" && c.Status == 1);
            List<U_User> userList = userBLL.FindAll();
            return View();
        }

使用Expression表達式分頁,註意 Linq分頁之前必須先排序 分頁代碼如下

    /// <typeparam name="TKey">排序的欄位類型</typeparam>
    /// <param name="pageIndex">當前頁</param>
    /// <param name="pageSize">每頁條數</param>
    /// <param name="orderby">排序欄位 Lambda表達式</param>
    /// <param name="where">查詢條件 Lambda表達式</param>
    /// <returns></returns>
    public List<U_User> GetPageList<TKey>(int pageIndex, int pageSize, Expression<Func<U_User, TKey>> orderby,Expression<Func<U_User, bool>> where = null)
    {
        using (EFContext db = new EFContext())
        {
            var query = from d in db.U_User select d;
            if (where != null)
            {
                query = query.Where(where);
            }
            var data = query.OrderBy(orderby)
            .Skip((pageIndex - 1) * pageSize)
            .Take(pageSize)
            .ToList();

            return data;
        }
    }

分頁方法調用

    public ActionResult Index()
    {
        List<U_User> userList = userBLL.GetPageList(1, 20, c => c.CreateTime, c => c.UserName == "nee32");
        return View(userList);
    }

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • vim /etc/inittab 3為預設進入文本界面, 5為預設進入圖形界面 文本界面下輸入init5或者startx切換圖形化界面 圖形化界面下輸入init3切換文本界面 ...
  • 1、查詢cpu的相關 a、查詢CPU的統計信息 使用命令:lscpu 得到的結果如下: b、查詢每個CPU信息 使用的命令:cat /proc/cpuinfo 得到如下結果: 2、查詢所有的pci設備信息(pci是一種匯流排,而通過pci匯流排連接的設備就是pci設備了,如今,我們常用的設備很多都採用p ...
  • Win10 連接L2TP VPN 失敗解決方法 iOS系統不知道在什麼時候,已經不支持PPTP VPN。偶爾的機會剛好看到github上的一鍵式VPN伺服器部署腳本 "setup ipsec vpn" ,就在 "VPS" 上部署了。系統是 Ubuntu 16.04 。 部署完成後在iPhond和iP ...
  • Ubuntu16.04 LTS下apt安裝WireShark 安裝與配置 1. 首先通過apt安裝WireShark: 會同時安裝許多的依賴包,其中包括一個叫做wireshark common的包,在dpkg預配置時會彈出對話解釋安裝選項,大意是 可以被安裝成允許在wireshark用戶組中的用戶抓 ...
  • 模式:pattern 正則: grep:基本正則 Extended grep:擴展正則 基本正則: . :任意單個字元 []:指定範圍內 [^]:指定範圍外 次數匹配 *:字元出現任意次 ?:字元出現0次或1次 \{m,n\}:字元至少出現m次,至多出現n次 \{1,\}:字元至少出現1次 .*:匹 ...
  • 引言 基於生成圖片實現了一個手機號轉圖片的需求。 內容也很簡單,直接用手機號生成一個png圖片。就是為了背景透明以便其他地方調用。 有無鋸齒主要依靠一句代碼:g.TextRenderingHint= TextRenderingHint.AntiAlias; 生成圖片 1、有鋸齒 2、無鋸齒 生成方法 ...
  • 操作步驟: 給頁面隱藏TextBox賦值,然後觸發ASP.NET change事件,調用ASP.NET後臺方法,調用後執行客戶端腳本this.RegisterClientScriptBlock(DateTime.Now.ToString(), script); 執行頁面的script;頁面的scri ...
  • System.Data.OleDb.OleDbException: 未指定的錯誤的解決方法 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...