【官方文檔】LINQ簡介
class Program
{
static void Main(string[] args)
{
string[] names = { "Alonso", "Zheng", "Smith", "Jones", "Smythe",
"Small", "Ruiz", "Hsieh", "Jorgenson", "Ilyich",
"Singh", "Samba", "Fatimah"};
//============================================================================
///查詢語法
///指定數據源:from in 子句
///指定條件:where 子句(可選)
///選擇元素:select 子句
var queryResults1 = from n in names where n.StartsWith("S") select n;
Console.WriteLine("查詢語法 結果");
foreach(var item in queryResults1)
{
Console.WriteLine(item);
}
Console.WriteLine("=====================================================");
//============================================================================
///查詢語法的強制立即執行
///要強制立即執行任何查詢並緩存其結果,可調用 ToList 或 ToArray 方法。
queryResults1 = (from n in names where n.StartsWith("S") select n).ToArray();
//============================================================================
///LINQ拓展方法
var queryResults2 = names.Where(n => n.StartsWith("S"));
Console.WriteLine("LINQ拓展方法 結果");
foreach (var item in queryResults2)
{
Console.WriteLine(item);
}
Console.WriteLine("=====================================================");
//============================================================================
///排序查詢結果:orderby 子句(可選)
///默認爲升序(A~Z),descending 降序關鍵字: orderby n descending
///按照最後一個字母排序:orderby n.Substring(n.Length - 1)
var queryResults3 = from n in names where n.StartsWith("S") orderby n select n;
Console.WriteLine("排序查詢結果 結果");
foreach (var item in queryResults3)
{
Console.WriteLine(item);
}
Console.WriteLine("=====================================================");
///多級排序(適用於帶多個屬性的對象)
///Orderby c.Region, c.Country,c.City
//============================================================================
///聚合運算符
///Min(),MAx(),Average(),Sum
Console.WriteLine("返回結果個數:" + queryResults3.Count());
Console.WriteLine("=====================================================");
//============================================================================
///單值選擇查詢
///去除重複值
var queryResults4 = (from n in names select n).Distinct();
queryResults4.Select(n => n).Distinct();
Console.ReadKey();
}
}