linq 查询 有两种语法  ,前面我们说了一种,接下来说方法语法(我读着一直很绕口)

查询语法,方法语法

------------------------以下文字都是复制-----------------------------------

LINQ的优势

1、无需复杂学习过程即可上手   
      2、编写更少代码即可创建完整应用。   
      3、更快开发错误更少的应用程序。   
      4、无需求助奇怪的编程技巧就可合并数据源。   
      5、让新开发者开发效率更高。   
      6、任何对象或数据源都可以定制实现Linq适配器,为数据交互带来真正方便。

这种可以看这个, 这些字我都是复制的 给你们链接看看  https://blog.csdn.net/huchunfu/article/details/8245157

1、查询语法:

如:from p in Products select p;

2、方法语法:

如:Where()

OrderBy()

Select()

注意  方法语法好像也有sql语句的语法规则  比如  where 在order 前面

lists.Where(n => n.Contains("a")).OrderBy(n => n.Length).Select(n => n.ToUpper());  可以运行

但是我把他这样就不能了

lists.OrderBy(n => n.Length).Select(n => n.ToUpper()).Where(n => n.Contains("a"));

--------------------------------分割线------------------------------------------------------

下面进入主题

1查询出所有含有a的字符串 不区分大小写

string[] list = {"AAAA","ABBBB","ABCCCC","ABCDDDD" };  //随便打的

var Quert = list

.Where(n => n.Contains("a"))  //检测有没有a

.OrderBy(n => n.Length)     //排序, 根据长度排序

.Select(n => n.ToLower());  //转换大小写

ViewBag.ddd = Quert;  //报错在这里  然后输出

注意: var  可以变成IEnumerable   这是一个接口类型的  也可以简单的写成var

代码

  public ActionResult Index()
{
//方法语法
string[] list = {"AAAA","ABBBB","ABCCCC","ABCDDDD" };
var Quert = list.Where(n => n.Contains("A")).OrderBy(n => n.Length).Select(n => n.ToLower());
ViewBag.ddd = Quert;
return View();
}

你们看看注释  ( 懒得打了 你们了解一下,下面才是正确代码)

@item 这样子才能正确输出信息 如果不加@,不然的话 只是输出item(一个毫无意义的item字符串)

@foreach (var item in ViewBag.ddd)
{
<h2>@item</h2> }

正确代码

这样子 就出来了

注意 LINQ方法语法,一般都是和lambda一起使用的

2  输出多个信息显示(linq查询语法和方法语法)

1 查询出所有年龄大于等于19的信息

创建一个Person 类

public class Person
{
public int Age { get; set; }
public string Name { get; set; }
public string Title { get; set; }
}

public ActionResult Index()
{

List<Person> person = new List<Person>{
new Person(){ Name="cl" , Title="my", Age=18},
new Person(){ Name="cl1" , Title="my", Age=19},
new Person(){ Name="cl2" , Title="my", Age=20}
};
// var Linq = from p in person where p.Age >= 19 select p; //LINQ查询语法
//LINQ方法语法
var Linq = person.Where(n=>n.Age>=19);    //  LINQ方法语法   你们自行比较
ViewBag.mes = Linq;

return View();
}

index视图

@foreach (var item in ViewBag.mes )  //  前面已经说了原因  一行语句只能写一个@
{
<h2><span>年龄:</span> @item.Age,<span>名字:</span>@item.Name</h2>  // 由于是多个参数, 所以 带了参数
}

完毕,  欢迎交流!!!

四:MVC之LINQ方法语法的更多相关文章

  1. 二:MVC之LINQ查询语法

    LINQ(Language Integrated Query)语言集成查询是一组用于c#和Visual Basic语言的扩展.它允许编写C#或者Visual Basic代码以操作内存数据的方式,查询数 ...

  2. LINQ之路 4:LINQ方法语法

    书写LINQ查询时又两种语法可供选择:方法语法(Fluent Syntax)和查询语法(Query Expression). LINQ方法语法是非常灵活和重要的,我们在这里将描述使用链接查询运算符的方 ...

  3. linq查询语法和方法-簡單用法

    來自:http://www.cnblogs.com/knowledgesea/p/3897665.html 1.简单的linq语法 //1 var ss = from r in db.Am_recPr ...

  4. LINQ之方法语法

    上节讲到使用linq的查询关键字进行查询,这节讲一下linq查询的另一种方式--linq方法. 使用linq方法语法,必须要会用lambda表达式,配合lambda表达式才能体会到linq的优雅便捷. ...

  5. LINQ教程二:LINQ操作语法

    LINQ查询时有两种语法可供选择:查询表达式语法(Query Expression)和方法语法(Fluent Syntax). 一.查询表达式语法 查询表达式语法是一种更接近SQL语法的查询方式. L ...

  6. .NET LINQ查询语法与方法语法

    LINQ 查询语法与方法语法      通过使用 C# 3.0 中引入的声明性查询语法,介绍性 LINQ 文档中的多数查询都被编写为查询表达式. 但是,.NET 公共语言运行时 (CLR) 本身并不具 ...

  7. C#3.0新增功能09 LINQ 基础07 LINQ 中的查询语法和方法语法

    连载目录    [已更新最新开发文章,点击查看详细] 介绍性的语言集成查询 (LINQ) 文档中的大多数查询是使用 LINQ 声明性查询语法编写的.但是在编译代码时,查询语法必须转换为针对 .NET ...

  8. Linq学习(主要参考linq之路)----2LINQ方法语法

    方法语法:Fluent Syntax 方法语法是非常灵活和重要的.我们这里讲描述使用连接查询运算符的方式来创建复杂的子查询,方法语法的本质是通过扩展方法和Lambda表达式来创建查询. eg1: st ...

  9. 探讨mvc下linq多表查询使用viewModel的问题

    最近在开发mvc3的时候发现了一个问题,就是如何在view页面显示多表查询的数据,最简单的办法就是使用viewmodel了,以下本人使用viewmodel来实现多表查询的3中方法, 先贴代码再说: 1 ...

随机推荐

  1. PhpStorm设置项目编码

    因为工作中论坛项目用的是GBK编码.数据库也是GBK编码.模板也是GBK,所以为了以后修改程序不出现乱码问题,所以需要把我的PhpStorm中该项目也设置为GBK编码(默认是UTF8编码). 设置路径 ...

  2. es6 是否包含字符串判断

    字符串查找类 接下来介绍一些可以通过 ES5 PolyFill的方法,但是现在 ES6 原生实现了 Method Param Return Description includes() 需要验证是否被 ...

  3. 如何在mac上安装gitlab

    安装docker 下载地址:https://docs.docker.com/docker-for-mac/install/ 下载下来是一个dmg的安装包,直接安装就可以了. 网络问题 嗯,在国内做开发 ...

  4. glew, glee与 gl, glu, glut, glx, glext的区别和关系

    GLEW是一个跨平台的C++扩展库,基于OpenGL图形接口.使用OpenGL的朋友都知道,window目前只支持OpenGL1.1的涵数,但 OpenGL现在都发展到2.0以上了,要使用这些Open ...

  5. 信用卡分销系统源码、分销系统定制贴牌、信用卡三级分销系统源码、信用卡返佣系统OEM

    信用卡返佣分销系统贴牌,全套源码,可定制UI界面 这一整套绝对是市场上最完善最好的一套系统:里面的特色功能: 1.合伙人功能,解决你前期的资金以及资源问题 2.推广素材库,全方位增加推广效率 3.红包 ...

  6. pytest.mark.parametrize()参数化的应用一

    from page.LoginPage import Loginpage import os, sys, pytest base_dir = os.path.dirname(os.path.dirna ...

  7. Spring 控制器重定向

    1.示例 return "redirect:/allUser"; redirect是跳转的意思后面是跳转的页面

  8. java -io 读取文件操作

    主要分为字节读取和字符读取,字节读取可以一个一个读取和字节数组读取,字符读取同样之,字符读取适合文本读取,字节读取皆可以 这里直接上代码,读取文件的9个小demo package com.io; im ...

  9. 《Tsinghua oc mooc》第5~7讲 物理内存管理

    资源 OS2018Spring课程资料首页 uCore OS在线实验指导书 ucore实验基准源代码 MOOC OS习题集 OS课堂练习 Piazza问答平台 暂时无法注册 疑问 段式内存管理中,逻辑 ...

  10. linux命令(ubuntu18)记录...

    1.解压.zip文件unzip unzip studentCRUD-master.zip              2.读写权限chmod指令 r表是读 (Read) .w表示写 (Write) .x ...