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

  • 相关阅读:
    计算机科学中最重要的32个算法
    主流无线传输技术GPRS与CDMA之对比
    GPRS、GSM、WAP、CDMA 、EDGE和3G区别
    TCP与UDP的区别
    web自动化测试(java)---测试过程中遇到的错误合集
    web自动化测试(java)---环境搭建
    Java之基础学习(数据类型、运算符、分支语句和循环语句)
    OSI七层模型和tcp/ip四层模型对比
    测试工具之Match Tracer(正则表达式匹配工具)
    测试工具之RobotFramework关键字和快捷键
  • 原文地址:https://www.cnblogs.com/wangcongsuibi/p/8873532.html
Copyright © 2020-2023  润新知