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. ftp的本地用户搭建

    前期的准备跟虚拟用户一样,就是配置文件不一样 修改配置文件 就是共享的都是自己的账号的家目录,然后启动服务就可以了 本地登陆的都是自己的账号密码 ftp本地的黑名单,

  2. 公客网beta阶段发布说明

    项目 公客 公正客观的课程评价网站 功能说明 评价的增删改 对课程发表评价 限制评价次数(3次),删除与增量修改评价 评价下的讨论与点赞 在评价下添加讨论,支持在讨论中使用@与对方交流想法 为评价点赞 ...

  3. Linux下系统的定时及延时任务

    一.系统的延时 是临时的.对系统做的任务指定一个时间点.发起的命令是at at    时间点(now+1min)      ## 设定任务实行时间 at>  执行命令               ...

  4. defer async 区别

    链接 <script src="script.js"></script> 没有 defer 或 async,浏览器会立即加载并执行指定的脚本,“立即”指的是 ...

  5. echarts-detail--柱状图

    一:柱形图 1.Echarts-柱状图柱图宽度设置-----只需要设置series中的坐标系属性barWidth就可以 /** * 堆积柱状图 * @param xaxisdata x轴:标签(数组) ...

  6. 目标检测 - Tensorflow Object Detection API

    一. 找到最好的工具 "工欲善其事,必先利其器",如果你想找一个深度学习框架来解决深度学习问题,TensorFlow 就是你的不二之选,究其原因,也不必过多解释,看过其优雅的代码架 ...

  7. rest-framework框架 -- 认证权限流程源码

    认证权限 解析BaseAuthentication源码 # 做认证权限 from rest_framework import exceptions from ..models import * cla ...

  8. 原生js实现div拖拽

    十分简单的效果. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...

  9. Android:BroadcastReceiver

    参考:<第一行代码:Android> 郭霖(著)   Broadcast分类 注册方式: 动态广播 在代码中注册receiver 一定要手动在onDestroy()时调用unregiste ...

  10. 应该抛出什么异常?不应该抛出什么异常?(.NET/C#)

    我在 .NET/C# 建议的异常处理原则 中描述了如何 catch 异常以及重新 throw.然而何时应该 throw 异常,以及应该 throw 什么异常呢? 究竟是谁错了? 代码中从上到下从里到外 ...