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 对象

  • 相关阅读:
    (转) Nova是如何统计OpenStack资源
    (转) 一次批量重启引发的Neutron网络故障
    (转)理解Keystone的四种Token
    neutron 虚拟机网络问题调试
    转 Nova: 虚机的块设备总结 [Nova Instance Block Device]
    kvm 客户机系统的代码是如何运行的
    12 while循环
    11猜拳游戏
    10 if 嵌套
    09 if...elif..else语句
  • 原文地址:https://www.cnblogs.com/wangcongsuibi/p/8873532.html
Copyright © 2011-2022 走看看