Linq 处理 List数据
概述:LINQ又称为语言集成查询,是一种类似于SQL的一种查询语言。语言集成查询让开发人员可以使用.NET程序语言(如C#)去查询数据源,主要数据源为内存中的集合对象、ADO.NET数据集、数据库以及XML,开发人员不用去分门别类地学习众多的查询语法就可以轻松地查询异构数据源。
三种表现形式:复合查询、Lambda表达式以及混合查询。
1、查询集合数据方法依次为:
复合查询:
var result=from n in dataList orderby n.TimeWritten descending select n; //可以将n看做是dataList,得到的结果是dataList里面所有值按时间字段的降序排列。
Lambda表达式查询:
var result=dataList.Select(p=>new{p.ID,p.Name,p.TimeWritten}); //Lambda表达式由匿名方法演变而来。这段Code中p为参数,多个参数可用(p,m..)表示。"=>"为推出符号,后面为返回值。该事例的返回值为对象中指定的字段。
混合查询:
var result=from n in dataList select n.OrderByDescending(p => p.TimeWritten); //查询集合所有数据按照时间字段降序来排序。升序为OrderBy()。
2、删除数据
List<NewSingle> dataList=new List<NewSingle>();
NewSingle single=dataList.Single(p=>p.ID==1);
dataList.DeleteOnSubmit(NewSingle);
dataList.SubmitChanges();
3、插入数据
NewSingle single=new NewSingle();
single.Name="Test1";
single.TimeWritten=this.DateTime.Now.ToString();
single.Subject="subject";
dataList.InsertOnSubmit(single);
dataList.SubmitChanges();
4、修改数据
NewSingle single=from n in dataList where n.ID == 3 select n;
single.Name="Test2";
single.TimeWritten="2011-3-17";
single.Subject="subject2";
dataList.SubmitChanges();
注:linq中不支持Convert转换。
5、查询绑定DropDownList
var data=from n in dataList select new { Name=n.Name,ID=n.ID};
DropDownList1.DataTextField="Name";
DropDownList1.DataValueField="ID";
DropDownList1.DataSource=data;
DropDownList1.DataBind();
6、绑定GridView
GridView1.DataSource=dataList.Select(p=>p);
GridView1.DataBind();
7、表联接
var result=from a in mytest.stuInfo join b in mytest.stuMarks on a.stuNo equals b.stuNo (into c) select new {Name=a.stuname,b.writtenExam};
8、其他方法
DeleteAllOnSubmit<T>(object) 删除T类型的对象
Where() 条件查询返回bool
GroupBy() 分组
SubString(n,m) 从n开始截取m条数据
Skip(number)跳过指定数量的项 】常用于表格分页
Take(number) 提取指定数量的项 】
TakeWhile() 根据指定条件提取
SkipWhile() 根据指定条件跳选项,从第一个不符合小件的项开始提取
ThenBy(s=>s.Name) 复合排序,出现在多字段列表中,置于在OrderBy后面
Distinct() 过滤重复数据
ToList() 转换成List
Count() 数据总数
Max()/Min() 最大值/最小值
Average() 平均值
Sum() 总和
Range() 例:num=Enumerable.Range(1,10) 从1开始产生十个数据
Repeat(重复值,重复次数) 生成重复项
传送门:http://blog.163.com/lm_regina/blog/static/17419653620110287530239
Linq 处理 List数据的更多相关文章
- Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数
11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...
- linq根据传入数据集合查询对应子级数据
工作中经常用到的linq根据传入数据集合查询对应子级数据,整理共享,希望大家都能用得上,代码中doublesArray 为父节点对应ID数据集合,再根据ID数据集合查询全部子级数据. //获取缓存数据 ...
- linq依据传入数据集合查询相应子级数据
工作中经经常使用到的linq依据传入数据集合查询相应子级数据,整理共享,希望大家都能用得上,代码中doublesArray 为父节点相应ID数据集合,再依据ID数据集合查询所有子级数据. //获取缓存 ...
- LINQ和.NET数据访问
.NET数据访问 在.NET中对于数据的访问大致有三个层面,数据访问层.内存数据集.业务逻辑层.数据层,包括了XML配置文件以及一些常用的数据库(使用SQL语句):内存数据集,主要是DataSet数据 ...
- mvc+linq+EF对数据表的查删改
/// <summary> /// 查询数据库中学生姓名 /// </summary> /// <returns></returns> public A ...
- C# Linq处理list数据
获取数据列表. //获取数据列表,Model是类 IList<Model> list = dao.getmx(Model, pageInfo);//DataTable数据DataTable ...
- Linq处理list数据
获取数据列表. //获取数据列表,Model是类 IList<Model> list = dao.getmx(Model, pageInfo);//DataTable数据DataTable ...
- Linq中字段数据类型转换问题(Linq to entity,LINQ to Entities 不识别方法"System.String ToString()"问题解决)
1.在工作中碰到这样一个问题: 使用linq时,需要查询两个表,在这两张表中关联字段分别是int,和varchar()也就是string,在linq中对这两个字段进行关联, 如果强制类型转换两个不同类 ...
- 通过Linq查找重复数据
一.模拟初始化集合数据 List<Student> students = new List<Student>() { new Student(){ Age=18,Name=&q ...
随机推荐
- Android-available for offline mode
出现 available for offline mode 字样的异常: 取消打钩 Offine work 点击sync project ..... 成功解决:
- collaborative filtering协同过滤
每次我想看电影的时候,都会去问我的朋友,小健.一般他推荐的电影,我都比较喜欢.显然不是所有人都有小健这样的能力.因为我碰巧和小健有类似的品味. 这个生活中的经验,实际上有着广泛的用途. 当系统需要为某 ...
- FastReport使用方法(C/S版)
前言 这两天群里一直有群友问一些关于FastReport的问题,结合他们的问题,在这里做一个整理,有不明白的可以加 FastReport 交流群 群 号:554714044 工具 VS2017 + ...
- EFCore2.1中DbFirst和CodeFirst简单使用
EFCore中没有DbFirst了吧,应该都是Code First 先说说第一种,Code First From Database(DbFirst)数据库先行,这种方式就要命令行了...(特不喜欢命令 ...
- Python运维脚本整理
Python 实现的自动化服务器管理 import sys import os import paramiko ssh = paramiko.SSHClient() ssh.set_missing_h ...
- 重拾 BFC、IFC、GFC、FFC
温故知新,巩固基础 从 FC 开始 FC,Formatting Context,格式化上下文,是 W3C CSS2.1 规范中的一个概念,定义的是页面中一块渲染区域,并且有一套渲染规则,它决定了其子元 ...
- D02-R语言基础学习
R语言基础学习——D02 20190423内容纲要: 1.前言 2.向量操作 (1)常规操作 (2)不定长向量计算 (3)序列 (4)向量的删除与保留 3.列表详解 (1)列表的索引 (2)列表得元素 ...
- Shell - 简明Shell入门04 - 判断语句(If)
示例脚本及注释 #!/bin/bash var=$1 # 将脚本的第一个参数赋值给变量var if test $var # test - check file types and compare va ...
- cAdvisor+InfluxDB+Grafana 监控Docker
容器的监控方案其实有很多,有docker自身的docker stats命令.有Scout.有Data Dog等等,本文主要和大家分享一下比较经典的容器开源监控方案组合:cAdvisor+InfluxD ...
- dubbo管控台安装
1. jdk安装 # cp installpkgs/jdk-7u67-linux-x64_tar_gz /usr/local # tar -zxf jdk-7u67-linux-x64_tar_g ...