中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c#中LINQ的基本用法實例

發布時間:2020-08-27 10:24:02 來源:腳本之家 閱讀:160 作者:阡陌染 欄目:編程語言

一、什么是LINQ

LINQ(讀音link)代表語言集成查詢(Language Integrated Query),是.NEt框架的擴展,它允許我們用SQL查詢數據庫的方式來查詢數據的集合,使用它,你可以從數據庫、程序對象的集合以及XML文檔中查詢數據

下面一個簡單的示例,可以查詢數組中小于8的數字并輸出。

一般步驟:獲取數據源、創建查詢、執行查詢。需要注意的是,盡管查詢在語句中定義,但直到最后的foreach語句請求其結果的時候才會執行

using System;
using System.Collections.Generic;
using System.Linq;

namespace LINK查詢
{
 class Program
 {
 static void Main(string[] args)
 {
  int[] number = { 2, 4, 6, 8, 10 }; //獲取數據源
  IEnumerable<int> lowNum = from n in number //創建并存儲查詢,不會執行操作
     where n < 8
     select n;

  foreach(var val in lowNum) //執行查詢
  {
  Console.Write("{0} ", val);
  }

  Console.ReadKey();
 }
 }
}

二、查詢表達式的結構

查詢表達式由查詢體后的from子句組成,其子句必須按一定的順序出現,并且from子句和select子句這兩部分是必須的。先介紹一下子句

2.1 from子句

from子句指定了要作為數據源使用的數據集合,它的語法是:

from Type Item in Items

其中Type是集合中元素的類型,是可選的,因為編譯器可以從集合來推斷類型。  Item是迭代變量的名字。  Items是要查詢的集合的名字,必須是可枚舉類型的

它和foreach比較相似,但foreach語句在遇到代碼時就執行其主體,二from子句什么也不執行。它創建可以執行的后臺代碼對象,只有在程序的控制流遇到訪問查詢變量的語句時才會執行

2.2  join子句

如果您對SQL中的join比較熟悉的話,那么LINQ中的join對你來說也不是什么難事,不熟悉的話,,當我沒說。

我們可以使用join來結合兩個或更多集合中的數據,它接受兩個集合然后創建一個臨時的對象集合

var query = from s in students
  join c in course on s.SID equals c.SID

equals用于比較相等性的字段,不能使用“==”代替,下面示例中有三個學生和三門課程,我們要做的是查找選修了歷史課的學生名

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace LINK查詢
{
 class Program
 {
 public class Student //聲明student類
 {
  public int stId; //學生ID
  public string stuName; //學生姓名
 }

 public class Course //聲明course類
 {
  public int stId; //學生ID
  public string courseName; //課程名
 }

 static Student[] students = new Student[]
 {
  new Student {stId = 1,stuName = "jack"},
  new Student {stId = 2,stuName = "taylor"},
  new Student {stId = 3,stuName = "fleming"}
 };

 static Course[] courses = new Course[]
 {
  new Course{stId = 1,courseName = "art"},
  new Course{stId = 2, courseName = "art"},
  new Course{stId = 1,courseName = "history"},
  new Course{stId = 3, courseName = "history"},
  new Course{stId = 3,courseName = "physics"},
 };

 static void Main(string[] args)
 { 
  //查詢所有選修了history課的學生名
  var query = from s in students
   join c in courses on s.stId equals c.stId
   where c.courseName == "history"
   select s.stuName;

  foreach(string str in query)
  {
  Console.Write("{0} ", str);
  }
  Console.ReadKey();
 }
 }
}

輸出 jack fleming

講解一下查詢過程:它會依次使用student中的對象與course中的所有對象進行對比,查找是否符合 s.stId equals c.stId where c.courseName == "history" 要求。

stID stuName
1 jack
2 taylor
3 fleming

 

 stID  courseName
 1  art
 2  art
 1  history
 3  history
 3  physics

即先將(1,jack)和(1,art),(2,art)...(3,physics)分別匹配,然后再(2,taylor)和(1,art),(2,art)...(3,physics),直到所有都匹配完,最終可以找到兩條可以匹配的結果

2.3 let子句

let子句接受一個表達式的運算并且把它賦值給一個需要在其他運算中使用的標識符,它是from...let...where片段中的一部分

var query = from a in groupA
   from b in groupB
   let sum = a + b
   where sum < 12
   select new(a,b,sum);

2.4 where子句

where子句根據之后的運算來除去不符合要求的項,一個查詢表達式可以有任意多個where子句,一個項必須滿足所有的where條件才能避免被過濾,其語法為

where BoolenExpression1
where BoolenExpression2

前面的例子已經多次用過where,這里就不舉例了

2.5 orderby子句

orderby可以很方便的將返回的數據進行排序,可選ascending和descending兩種方式,默認的是ascending

語法: orderby Expression ascending or descending 二選一

為join子句中的例子增加一個orderby子句,返回結果就變成了 fleming jack

var query = from s in students
      join c in courses on s.stId equals c.stId
      where c.courseName == "history"
               orderby s.stuName  //排序
      select s.stuName; 

2.6 group子句

group子句可以讓你把select的結果按指定的鍵(key)進行分組 ,每一個分組由一個叫做鍵的字段區分,分組本身是可枚舉類型的并且可以枚舉它的項

var query = from student in students
   group student by student.major;

   foreach (var s in query)
   {
    Console.WriteLine("{0}", s.key);
    foreach (var t in s)
    {
     console.writeLine(" {0}", t.Name);
    }
   }

2.7 select子句

select子句指定所選定的對象哪部分應該被選擇。可以指定下面的任意一項

a: 整個數據項

b: 數據項的一個字段

c: 數據項中幾個字段組成的新對象(或類似其他值)

var query = from s in students
      select s; //整個數據項

   var query = from s in students
      select s.stuName; //s中的一個字段

   var query = from a in groupA
      from b in groupB
      let sum = a + b
      where sum < 12
      select new (a, b, sum);  //a,b,sum組成的新字段

2.8 查詢延續: into子句

查詢延續子句可以接受查詢的一部分結構并賦予一個名字,從而可以在查詢的另一部分中使用

var someInt = from a in groupA
    from b in groupB
    into groupAandB
    from c in groupAandB
    select c;

三、方法語法和查詢語法

在使用LINQ寫查詢時可以使用兩種形式的語法:查詢語法和方法語法

  a:方法語法(method syntax) : 使用標準的方法調用,這些方法是一組叫做標準查詢運算符的方法

  b:查詢語法(query method) : 看上去和SQL語句很相似,使用查詢表達式形式書寫。微軟推薦使用查詢語法,因為它更易讀

在編譯時,CLR會將查詢語法轉換為方法語法

int[] num = { 2, 4, 6, 8, 10 };

 var numQuery = from number in num //查詢語法
    where number < 8
    select number;

 var numMethod = num.Where(x => x < 8); //方法語法

它們得到的結果是一樣的。方法語法中where的參數使用了Lambda表達式

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

卓尼县| 沁水县| 大埔县| 绵阳市| 大方县| 额尔古纳市| 翼城县| 陆河县| 佳木斯市| 金堂县| 吉林市| 巫溪县| 泽库县| 南通市| 富宁县| 丹寨县| 吴忠市| 民乐县| 合水县| 花莲县| 辽阳市| 苏尼特左旗| 宁海县| 广德县| 万全县| 青铜峡市| 德江县| 衡阳县| 建瓯市| 闵行区| 鄂温| 石台县| 鄯善县| 如皋市| 康乐县| 姜堰市| 华蓥市| 乳源| 三河市| 云浮市| 会泽县|