zoukankan      html  css  js  c++  java
  • entity framework 新手入门篇(1.5)-lambda表达式与linq

    在建立好了EF模型之后,先不着急使用它,在使用它之前,你还需要了解两个相关的技术,lambda表达式与linq。

    作为微软C#语言中重要的语法糖-lambda表达式与LINQ,本质都是一个方法,以lambda表达式为例:

    x=>x+1;就是一个完整的lambda表达式。

    其等同于一个匿名的方法:

    int anonymous(int x)

    {

      return x+1;

    }

    考虑一下这个方法中最重要的部分,也就两个部分:传入的参数,返回的参数。

    返回值类型,参数类型都是可以进行推断的,就像C#中的VAR关键字。所以,X=>X+1就是一个最简单的x++的lambda表达式的实现。

    知道了它的本质,那我们应该怎么使用它呢?我来举一个最简单的例子:从一个不规则的字符串数组中取出所有以s开头的字符串

    看到这里,最直接,最小白的写法:

    循环整个数组,找到字符串里S的索引为0的字符串,加入到新的LIST中。

    除了这个,其实还有更优雅,更面向对象的一些的写法,例如:

    但这两种写法, 我们都写了一个循环,新建了一个集合来收集所有符合条件的变量。接下来,如果使用lambda或者LINQ将会如何呢?

    这一段,完整的包括了新建元数据,使用两种写法进行筛选,最终打印到屏幕。

    第一句是建立元数据,不做详解,第二句是linq语句的写法

    from X in XXX where true select x是linq的经典句式,x为临时变量,与lambda表达式中的x相同。XXX是可枚举类型,如数组,集合等。where后面是一个BOOL值用作判断条件,最终select后面的,就是返回值了。我们返回了X,并最终使用了TOARRAY方法,所以,最终的数据类型是string[].(如果使用ToList()方法,将最终得到集合类List<string>)。

    第三句是lambda写法,where()表示查询的条件,如果需要明显指定取出的值,还可以在where方法后再接一句.select(x=>x)。当然在这里我们只取一个值,就显得毫无必要了。

    看完了这个例子,是不是想问,这与EF有个毛的关系?

    其实,这个例子用在数据库查询中,就相当于select id from table1 where name like 's%';

    而这个例子只要稍加改动,就能变成EF中最重要的查询手段。

  • 相关阅读:
    Hibernate4与Spring3的不兼容问题
    关于Struts2框架下jsp获取action的布尔值问题
    js 操作select和option常见用法
    用socaket编写客户端与服务端程序相互发送消息
    Web编程
    第二篇
    java基础
    GeoServer style标注中文乱码配置
    RabbitMQ高可用方案总结
    Visual Studio 2019 注册KEY
  • 原文地址:https://www.cnblogs.com/Damos/p/EF_1-5.html
Copyright © 2011-2022 走看看