zoukankan      html  css  js  c++  java
  • 作业6

          上节课跟着老师学到了不少知识,我主要了解到了.NET Programming的一些用处和优点,然后又学习了一些LINQ的用法。LINQ(即Language-INtegrated Query)

    LINQ 查询
    首先来看一个很简单的LINQ查询例子,查询一个int 数组中小于5的数字,并按照大小顺序排列:
    class Program { static void Main(string[] args) { int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 };
    var m = from n in arr where n < 5 orderby n select n; foreach (var n in m) { Console.WriteLine(n); } Console.ReadLine(); } }
    上述代码除了LINQ查询语法外,其他都是我们所熟悉的语法,而LINQ查询语法跟SQL查询语法很相识,除了先后顺序。

    我们再来看一个稍稍复杂的LINQ查询:
    在我们罗列的语言字符串中,我们希望按照字符长短,分类罗列出来,实现代码如下:
    static void Main(string[] args)
    {
    string[] languages = { "Java", "C#", "C++", "Delphi", "VB.net", "VC.net", "C++Builder", "Kylix", "Perl", "Python" };
    var query = from item in languages
    group item by item.Length into lengthGroups
    orderby lengthGroups.Key
    select lengthGroups;
    foreach (var item in query)
    {
    Console.WriteLine("strings of length{0}", item.Key);
    foreach (var val in item)
    {
    Console.WriteLine(val);
    }
    }
    Console.ReadLine();
    }
    其中的 into 关键字表示 将前一个查询的结果视为后续查询的生成器,这里是跟 group by 一起使用的。
    LINQ中的Group by不要跟 SQL 中的Group by 混淆,SQL由于是二维结构,Group by 的一些逻辑受二维结构的约束,无法像 LINQ 中的Group by 这么灵活。
    事实上,LINQ的查询语法存在以下两种形式:
    查询方法方式:(Methord Syntax)
    主要利用System.Linq.Enumerable类中定义的扩展方法和Lambda表达式方式进行查询
    查询语句方式:(Query Syntax)一种更接近SQL语法的查询方式,可读性更好。

     

     

  • 相关阅读:
    004: 基本数据类型-List
    003: 基本类型-字符串类型
    002: 基本类型-数值型(int, float)
    001: Hello World
    Python中的单例模式的几种实现方式的及优化
    django之admin组件
    权限管理---设计分析以及具体细节
    基于Form组件实现的增删改和基于ModelForm实现的增删改
    Python常见问题系列
    django的render的说明
  • 原文地址:https://www.cnblogs.com/lixuntaohaolihai/p/4461787.html
Copyright © 2011-2022 走看看