zoukankan      html  css  js  c++  java
  • CopyToDataTable()、SetField()

    1、用查询创建数据表
     static void UseCopyToDataTable() {
                DataSet ds = BuildOneDTDataSet();//数据源
                DataTable student = ds.Tables["PeopleDt"];
                DataTable score = ds.Tables["Scores"];
                var query = from stu in student.AsEnumerable()
                            from sco in score.AsEnumerable()
                            where stu.Field<int>("Age") > 20 && stu.Field<int>("ScoreID") == sco.Field<int>("ScoreID")
                            select stu;
                foreach (var item in query)
                {
                    Console.WriteLine("学生{0},年龄{1},性别{2}", item.Field<string>("Name"), item.Field<int>("Age"), item.Field<string>("XingBie"));
                }
                DataTable cnstudent = query.CopyToDataTable();
                foreach (var item in cnstudent.AsEnumerable())
                {
                    Console.WriteLine("学生{0},年龄{1},性别{2}", item.Field<string>("Name"), item.Field<int>("Age"), item.Field<string>("XingBie"));
                }
            }

    实际开发中CopyToDataTable通常用于界面绑定。

    2、修改表中数据字段

    static void UseSetField() {
                DataSet ds = BuildOneDTDataSet();
                DataTable dt = ds.Tables["PeopleDt"];
                foreach (var item in dt.AsEnumerable())
                {
                    int age=item.Field<int>("Age");
                    item.SetField<int>("Age",age+2);
                       Console.WriteLine("学生{0},年龄{1},性别{2}", item.Field<string>("Name"), item.Field<int>("Age"), item.Field<string>("XingBie"));
                }
    
                DataTable dt2 = ds.Tables["PeopleDt"];
                foreach (var item in dt2.AsEnumerable())
                {
                    Console.WriteLine("学生{0},年龄{1},性别{2}", item.Field<string>("Name"), item.Field<int>("Age"), item.Field<string>("XingBie"));
                }
    
                DataSet ds2 = BuildOneDTDataSet();
                DataTable dt3 = ds2.Tables["PeopleDt"];
                foreach (var item in dt3.AsEnumerable())
                {
                    Console.WriteLine("学生{0},年龄{1},性别{2}", item.Field<string>("Name"), item.Field<int>("Age"), item.Field<string>("XingBie"));
                }
            
            }

    由此可见SetFiled()修改的是Dataset中的数据,如果要保持元数据不变,要么在SetFiled()之前先备份数据表使用CopyToDataTable(),要么另起一个DataSet 对象

  • 相关阅读:
    js获取宽和高
    弹出一个登录层,并对登录进行校验
    存储过程事务处理
    C# 冒泡算法
    正则表达式30分钟入门教程
    生成树的两种递归方式
    (转)再说ActionMessages类及其用法
    java.io.IOException:stream closed 异常的原因及处理
    log4j学习
    struts1.x的国际化
  • 原文地址:https://www.cnblogs.com/wangcongsuibi/p/8873532.html
Copyright © 2011-2022 走看看