using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
namespace WebApplication_study.Linq
{
public partial class LinqStart : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = getDataTable.getData();//源数据
//Linq进行普通查询
var q1 = from dt1 in dt.AsEnumerable()//查询
orderby dt1.Field<int>("ID") descending//排序
where dt1.Field<int>("ID") > && dt1.Field<int>("ID") < //条件
select dt1;
Response.Write("查询结果为:<br/>");
foreach (var item in q1)//显示查询结果
{
//Response.Write("<br/>" + item.Field<string>("Name"));//两种写法均可
Response.Write("<br/>" + item["Name"]);
}
//查询结果用于新的DT
DataTable newDT = q1.CopyToDataTable<DataRow>();//经查询生成的DT可用于数据绑定
Response.Write("<br/><br/>新的DT的结果为:<br/>");
foreach (var item2 in newDT.AsEnumerable())//显示查询结果
{
Response.Write("<br/>" + item2["Name"]);
}
// 修改查询的结果
Response.Write("<br/>修改查询结果前:<br/>");
var q3 = from dt3 in dt.AsEnumerable()
select dt3;
foreach (var item in q3)
{
Response.Write("<br/>" + item["ID"] + "&nbsp;&nbsp;&nbsp;" + item["Name"] + "&nbsp;&nbsp;&nbsp;" + item["PID"] + "&nbsp;&nbsp;&nbsp;");
}
Response.Write("<br/>修改查询结果后:<br/>");
foreach (var items in dt.AsEnumerable())
{
int PID = (int)items["PID"];
items.SetField<int>("PID", PID + );
}
foreach (var item in q3)
{
Response.Write("<br/>" + item["ID"] + "&nbsp;&nbsp;&nbsp;" + item["Name"] + "&nbsp;&nbsp;&nbsp;" + item["PID"] + "&nbsp;&nbsp;&nbsp;");
}
//DataView测试
DataView dvDT = dt.AsDataView();
EnumerableRowCollection<DataRow> quert4 = from dv in dt.AsEnumerable() select dv;
DataView dvDTQ = quert4.AsDataView(); //linq调用本地方法
//定义本地方法
Response.Write("<br/>linq调用本地方法:<br/>");
int[] num = { , , , , , , , , };
var query = from i in num where check(i) select i;
foreach (var item in query)
{
Response.Write(item + " ");
}
}
/// <summary>
/// 本地方法示例
/// </summary>
/// <param name="num"></param>
/// <returns></returns>
public bool check(int num)
{
if (num > )
return true;
else
return false;
}
}
}

PS:如果出现指定转换无效的异常,说明查询语句里面有问题。一般是Field<T>的泛型有误,应当仔细检查DataTable中列的DataType。

  然后还可可以这么写

IEnumerable<DataRow> query =
from order in orders.AsEnumerable()
where order.Field<DateTime>("OrderDate") > new DateTime(, , )
select order; // Create a table from the query.
DataTable boundTable = query.CopyToDataTable<DataRow>();

本文转载自:http://www.cnblogs.com/sunxf2011/archive/2011/07/08/2101008.html

(转)Linq DataTable的修改和查询的更多相关文章

  1. ASP.NET MVC搭建项目后台UI框架—6、客户管理(添加、修改、查询、分页)

    目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NET MVC搭建项目后台UI框架—3.面板折叠和展开 ASP.NE ...

  2. linq根据传入数据集合查询对应子级数据

    工作中经常用到的linq根据传入数据集合查询对应子级数据,整理共享,希望大家都能用得上,代码中doublesArray 为父节点对应ID数据集合,再根据ID数据集合查询全部子级数据. //获取缓存数据 ...

  3. linq依据传入数据集合查询相应子级数据

    工作中经经常使用到的linq依据传入数据集合查询相应子级数据,整理共享,希望大家都能用得上,代码中doublesArray 为父节点相应ID数据集合,再依据ID数据集合查询所有子级数据. //获取缓存 ...

  4. 9_13学习完整修改和查询&&实体类,数据访问类

    完整修改和查询:中间变量运用. 1.先查 2.执行操作 ---------------------------------------------------- namespace ADO.NET_小 ...

  5. ADO.NET(完整修改和查询、实体类,数据访问类)

    一.完整修改和查询 在编写c#语句时需考虑到用户体验,例如在编写修改语句时,需要考虑到输入的内容在数据库中是否能够找到. 中间变量运用. 1.先查 2.执行操作 完整修改语句: bool has = ...

  6. HDU 3966 Aragorn's Story (树链点权剖分,成段修改单点查询)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3966 树链剖分的模版,成段更新单点查询.熟悉线段树的成段更新的话就小case啦. //树链剖分 边权修 ...

  7. linq里面似in的查询

    1.linq里面似in的查询 List<string> source = new List<string>{ "aaa", "bbb" ...

  8. MVC客户管理(添加、修改、查询、分页)

    ASP.NET MVC搭建项目后台UI框架—6.客户管理(添加.修改.查询.分页)   目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2 ...

  9. EFCore扩展:IQueryable(linq)或sql执行的查询缓存与清理

    前言 上一篇讲述了执行sql和配置的一些功能,这篇说明IQueryable(linq)或执行sql的查询缓存与清理,包括扩展到将缓存存储到Redis中. 扩展类库源码: github:https:// ...

随机推荐

  1. Java进阶1. Synchronized 关键字

    Java进阶1. Synchronized 关键字 20131025 1.关于synchronized的简介: Synchronized 关键字代表对这个方法加锁,相当于不管那一个线程,运行到这个方法 ...

  2. iTabs Tab切换插件

    最近项目中使用到Tab切换,切换的页面不变,内容发生变化,随手写了份简单的插件,附带源码.先看样子: 本人也考虑到是否使用jquery ui tab,但是还是热衷于自己写一份,首先好处之一是易于培训, ...

  3. LVS模式二:隧道模式(Tun)

    一.IP隧道(IP Tunneling) ip隧道是一个将ip报文封装到另一个ip报文的技术,这可以使得目标为一个ip地址的数据报文被封装和转发到另一个ip地址.ip隧道技术也成为ip封装技术.    ...

  4. node 适合 5000 人同时在线左右的 游戏开发

    游戏开发性能的一些讨论 上面这个问题是在游戏上线前的一个性能顾虑 (但他确实是node多进程通讯间的一个比较麻烦的问题,数据一大就会出现性能上的瓶颈) 我们项目(手游)已经上线了,单服最高同时在线4. ...

  5. (转) MapReduce Design Patterns(chapter 5 (part 1))(九)

    Chapter 5. Join Patterns 把数据保存成一个巨大的数据集不是很常见.例如,用户信息数据频繁更新,所以要保存到关系数据库中.于此同时,web日志以恒定的数据流量增加,直接写到HDF ...

  6. strip()函数和 split()函数

    一:python strip()函数介绍 函数原型:strip可以删除字符串的某些字符 声明:s为字符串,rm为要删除的字符序列 s.strip(rm)        删除s字符串中开头.结尾处,位于 ...

  7. iOS NSString相关问题

    1.NSString对象的创建 // 1.创建不可变字符串 NSString *str1 = @"create string"; #pragma mark 对象方法创建字符串 // ...

  8. git版本管理工具的使用

    Git的一些资料 --关于git的介绍就此忽略了--- Git官网http://git-scm.com/ Visual Studio Tools for Git下载地址https://visualst ...

  9. 为网站添加favicon.ico图标

    前言 貌似每次都是等到网站快收尾时才做favicon.ico的,这次也不例外.这年代…… 步骤 1.PS制作正方形图标,格式为jpg.jpeg.gif或png. 2.将图标转换为ICO格式,网上有很多 ...

  10. SpringDataJpa增删改查

    资料来源网址:http://www.cnblogs.com/hawell/p/SpringDataJpa.html Repository(几个常用的例子) @Repository public int ...