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

  • 相关阅读:
    关系型数据库范式 沧海
    面试注意事项 沧海
    怎样在面试后得到想要的职位 沧海
    应届大学毕业生面试应答 沧海
    二叉树的遍历及实现 沧海
    比较好的C++面试题 沧海
    多态 沧海
    应届大学毕业生面试应答 沧海
    SQL Server开发人员应聘常被问的问题 沧海
    面试成功的技巧与忠告 沧海
  • 原文地址:https://www.cnblogs.com/wangcongsuibi/p/8873532.html
Copyright © 2011-2022 走看看