C#动态操作DataTable(新增行、列、查询行、列等)

方法一:动态创建一个DataTable ,并为其添加数据

public void CreateTable()
        {
            //创建表
            DataTable dt = new DataTable();
           
            //1、添加列
            dt.Columns.Add("Name", typeof(string)); //数据类型为 文本

//2、通过列架构添加列
            DataColumn age = new DataColumn("Age", typeof(Int32));   //数据类型为 整形
            DataColumn Time = new DataColumn("Time", typeof(DateTime)); //数据类型为 时间
            dt.Columns.Add(age);
            dt.Columns.Add(Time);

//1、添加空行
            DataRow dr1 = dt.NewRow();
            dt.Rows.Add(dr1);

//2、添加空行
            dt.Rows.Add();

//3、添加数据行
            DataRow dr2 = dt.NewRow();
            dr2[0] = "张三"; //通过索引赋值
            dr2[1] = 23;
            dr2["Time"] = DateTime.Now;//通过名称赋值
            dt.Rows.Add(dr2);

//4、通过行框架添加
            dt.Rows.Add("李四",25,DateTime.Now);//Add你们参数的数据顺序要和dt中的列顺对应

}

方法二:为已有DateTable添加一新列,其值可设为默认值,也可设这列不可为空。

public void CreateTable(DataTable vTable)
        {
            //为已有DataTable添加一新列
            DataColumn dc1 = new DataColumn("Tol", typeof(string));
            vTable.Columns.Add(dc1);

//添加一新列,其值为默认值
            DataColumn dc2 = new DataColumn("Sex", typeof(string));
            dc2.DefaultValue = "男";
            dc2.AllowDBNull = false;//这在初床表的时候,其作用,在为已有表新增列的时候,不起作用
            vTable.Columns.Add(dc2);
        }

方法三:筛选DataTable中的数据,使用 Select()方法,把赛选结果可以保存到 DataRow[] drArr; 数据里面,也可以另存为一个新DataTable

public void SelectRowDataTable()
        {
            DataTable dt = new DataTable();//假设dt是由"SELECT C1,C2,C3 FROM T1"查询出来的结果
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                if (dt.Rows[i]["C1"].ToString() == "abc")//查询条件
                {
                    //进行操作
                }
            }
            //但这种做法用一两次还好说,用多了就累了。那有没有更好的方法呢?就是dt.Select(),上面的操作可以改成这样:

DataRow[] drArr = dt.Select("C1='abc'");//查询(如果Select内无条件,就是查询所有的数据)

//还可以这样操作:
            DataRow[] drArr1 = dt.Select("C1 LIKE 'abc%'");//模糊查询(如果的多条件筛选,可以加 and 或 or )
            DataRow[] drArr2 = dt.Select("'abc' LIKE C1 + '%'", "C2 DESC");//另一种模糊查询的方法
            DataRow[] drArr3 = dt.Select("C1='abc'", "C2 DESC");//排序

//问题又来了,如果要把DataRow赋值给新的DataTable,怎么赋值呢?你可能会想到:
            DataTable dtNew1 = dt.Clone();
            for (int i = 0; i < drArr.Length; i++)
            {
                dtNew1.Rows.Add(drArr[i]);
            }
           
            //但这样程序就会出错,说该DataRow是属于其他DataTable的,那要怎么做呢?很简单,这样就可以解决了:
            DataTable dtNew2 = dt.Clone();
            for (int i = 0; i < drArr.Length; i++)
            {
                dtNew2.ImportRow(drArr[i]);//ImportRow 是复制
            }
        }

方法四:对DataTable筛选指定字段,并保存为新表

public void SelectColumnDataTable(DataTable dt)
        {
            //对DataTable筛选指定字段,并保存为新表
            DataTable dtNew = dt.DefaultView.ToTable(false, new string[] { "列名", "列名", "列名" });//这些列名,确保dt中存在,否则会报错误
        }

方法五:对DataTable进行排序设置(sort)

public void SortDataTable(DataTable dt)
        {
            dt.DefaultView.Sort = "id desc";//重新设置排序
            DataTable dtNew = dt.DefaultView.ToTable(); //保存在一张新表中
        }

转载于:https://www.cnblogs.com/ToFlying/p/3421125.html

C#--动态操作DataTable相关推荐

  1. C#动态操作DataTable(新增行、列、查询行、列等)

    public void CreateTable()         {             //创建表             DataTable dt = new DataTable();    ...

  2. Ant Design of Vue —— setFieldsValue方法 动态操作Switch组件

    在开发中经常使用Form组件管理表单,这次想通过form提供的setFieldsValue()方法动态改变Switch组件状态,却没有生效. 加入valuePropName属性之后,就可以使用动态操作 ...

  3. .net使用SqlBulkCopy类操作DataTable批量插入数据库数据,然后分页查询坑

    在使用SqlBulkCopy类操作DataTable批量插入数据,这种操作插入数据的效率很高,就会导致每一条数据在保存的时间基本一样,在我们分页查询添加的数据是,使用数据的添加时间来排序就会出现每页的 ...

  4. 使用脚本动态操作 SVG 文档

    本教程适用于那些希望使用可伸缩向量图形(SVG)创建交互式 SVG 图形的开发人员.它讨论了使用ECMAScript(JavaScript)对现有的 SVG 图像进行实时操作得技术. 本文主要介绍在 ...

  5. 2022-04-07 西安 javaSE(04) 方法可变参数、重载、递归,数组、冒泡排序、二分查找、动态操作,二维数组、jvm内存区域划分

    方法 1.方法传递参数 形参是基本类型: 1.参数传递的内容是该基本类型的数据值.   2.对形式参数的改变不会影响实际参数的数据值 形参是引用类型:     1.参数传递的是地址值     2.对形 ...

  6. ava_212_反射机制_动态操作_构造器_方法_属性_练习

    package java_212_反射机制_动态操作_构造器_方法_属性_练习; /** 属性 */ public class User { private int id; private int a ...

  7. java 反射动态修改数据类型_[Java-基础]反射_Class对象_动态操作

    动态性 动态语言 在程序运行时,可以改变程序结构或变量类型,典型的语言: Python,ruby,javascript 如: function test(){ var s = "var a= ...

  8. 使用avaScript脚本动态操作 SVG 文档

    使用脚本动态操作 SVG 文档 陈珂 (chenke@snmobile.com), 技术总监, 南京安元科技 简介: 本教程适用于那些希望使用可伸缩向量图形(SVG)创建交互式 SVG 图形的开发人员 ...

  9. 利用JavaScript对HTML和CSS实现简单的动态操作

    假如我们现在想通过JS对原本的HTML或者CSS的内容或样式进行改变,比如说显示或隐藏内容.弹出各类对话框.改变内容的property.打开关闭窗口等等,我们应该怎么做呢? 首先我们先了解几个常用的J ...

最新文章

  1. 基于pytorch的模型稀疏训练与模型剪枝示例
  2. 如何查看CISCO FWSM上ACL分区的空闲资源
  3. wps分析工具库如何加载_关键词数据分析到底如何做?用这个工具比指数好
  4. SAP 电商云 Spartacus UI shipping method 切换时的 spinner 显示
  5. 【C++学习笔记一】C++类和对象详解
  6. 《树莓派开发实战(第2版)》——2.9 利用RDP远程控制树莓派
  7. 4G换5G关口,智能手机如何抢回“失去的一个月”
  8. bufferreader java_Java - BufferedReader对比FileReader到底哪里进行了优化
  9. 新型智慧城市 相关网址
  10. mysql for windows_mysql安装教程-windows版
  11. php curl 错误码,php,_PHP curl 错误 :curl__errno()返回错误码6,php - phpStudy
  12. 绕过TrustedInstaller权限
  13. 数仓建模—国产建模工具神器
  14. 华清远见重庆中心——HTML和CSS基础阶段技术总汇
  15. 网络基本功(二十三):Wireshark抓包实例诊断TCP连接问题
  16. 游戏专辑一 3D游戏碰撞之体素内存、效率优化(未完待续10/14)
  17. 2012年MacBook更换SSD固态硬盘和16G内存条
  18. http://yuanma.wxb0.com/ 唯品源码网站
  19. 大学计算机word试题文本,大学计算机考试word试题及答案
  20. ureport 显示html,Ureport2报表使用问题及注意事项汇总

热门文章

  1. POJ 3660 Cow ContestCow(Floyd传递闭包)题解
  2. Linux文件类型有哪些?
  3. 再次探扩展-对xVal进行扩展解决验证不同步的问题
  4. 使用 Application Developer V7 来创建和部署 JSR 168 协作 portlet
  5. 一步一步教你如何向ALEXA提交网站介绍信息
  6. Android开发之适配器模式初探
  7. Android Fragment 解析(上)
  8. 面试题目之 ----使用非迭代方法快速排序
  9. Android 数据库 ANR的例子
  10. Android7.0多窗口实现原理(二)