DataTable添加列和行的三种方法

摘要:
#region方法一:DataTabletblDatas=newDataTable("Datas");DataColumndc=null;dc=tblDatas.Columns.Add("ID",Type.GetType("System.Int32"));dc.AutoIncrement=true;//自动增加dc.AutoIncrementSeed=1;//起始为1dc.AutoIncremen
#region 方法一: 
DataTable tblDatas =new DataTable("Datas"); 
DataColumn dc =null; 
dc = tblDatas.Columns.Add("ID", Type.GetType("System.Int32")); 
dc.AutoIncrement =true;//自动增加 
dc.AutoIncrementSeed =1;//起始为1 
dc.AutoIncrementStep =1;//步长为1 
dc.AllowDBNull =false; 
dc = tblDatas.Columns.Add("Product", Type.GetType("System.String")); 
dc = tblDatas.Columns.Add("Version", Type.GetType("System.String")); 
dc = tblDatas.Columns.Add("Description", Type.GetType("System.String")); 
DataRow newRow; 
newRow =tblDatas.NewRow(); 
newRow["Product"] ="这个地方是单元格的值"; 
newRow["Version"] ="2.0"; 
newRow["Description"] ="这个地方是单元格的值"; 
tblDatas.Rows.Add(newRow); 
newRow =tblDatas.NewRow(); 
newRow["Product"] ="这个地方是单元格的值"; 
newRow["Version"] ="3.0"; 
newRow["Description"] ="这个地方是单元格的值"; 
tblDatas.Rows.Add(newRow); 
#endregion
#region 方法二: 
DataTable tblDatas =new DataTable("Datas"); 
tblDatas.Columns.Add("ID", Type.GetType("System.Int32")); 
tblDatas.Columns[0].AutoIncrement =true; 
tblDatas.Columns[0].AutoIncrementSeed =1; 
tblDatas.Columns[0].AutoIncrementStep =1; 
tblDatas.Columns.Add("Product", Type.GetType("System.String")); 
tblDatas.Columns.Add("Version", Type.GetType("System.String")); 
tblDatas.Columns.Add("Description", Type.GetType("System.String")); 
tblDatas.Rows.Add(newobject[] { null, "a", "b", "c"}); 
tblDatas.Rows.Add(newobject[] { null, "a", "b", "c"}); 
tblDatas.Rows.Add(newobject[] { null, "a", "b", "c"}); 
tblDatas.Rows.Add(newobject[] { null, "a", "b", "c"}); 
tblDatas.Rows.Add(newobject[] { null, "a", "b", "c"}); 
#endregion
#region 方法三: 
DataTable table =newDataTable(); 
//创建table的第一列 
DataColumn priceColumn =newDataColumn(); 
priceColumn.DataType = System.Type.GetType("System.Decimal");//该列的数据类型 
priceColumn.ColumnName ="price";//该列得名称 
priceColumn.DefaultValue =50;//该列得默认值 
//创建table的第二列 
DataColumn taxColumn =newDataColumn(); 
taxColumn.DataType = System.Type.GetType("System.Decimal"); 
taxColumn.ColumnName ="tax";//列名 
taxColumn.Expression ="price * 0.0862";//设置该列得表达式,用于计算列中的值或创建聚合列 
//创建table的第三列 
DataColumn totalColumn =newDataColumn(); 
totalColumn.DataType = System.Type.GetType("System.Decimal"); 
totalColumn.ColumnName ="total"; 
totalColumn.Expression ="price + tax";//该列的表达式,是第一列和第二列值得和 
//将所有的列添加到table上 
table.Columns.Add(priceColumn); 
table.Columns.Add(taxColumn); 
table.Columns.Add(totalColumn); 
//创建一行 
DataRow row =table.NewRow(); 
table.Rows.Add(row);//将此行添加到table中 
//将table放在视图中 
DataView view =newDataView(table); 
//绑定到DataGrid 
dg.DataSource =view; 
dg.DataBind(); 
#endregion
            DataTable table =SMRSCls.ReportCenter.ListCountSum(Keyword);
            table.Columns.Add("PriceSum", Type.GetType("System.Single"));//向table里增加多一列
              int RowsCount =table.Rows.Count;
            for (int j = 0; j < RowsCount; j++)//为该列增加相应的数值
{
                int CustomerID = Convert.ToInt32(table.Rows[j]["CustomerID"].ToString());
                int ProjectID = Convert.ToInt32(table.Rows[j]["ProjectID"].ToString());
                int Account =SMRSCls.ReportCenter.AccountPrice(CustomerID,ProjectID);
                table.Rows[j]["PriceSum"] =Account;
            }
            DataTable dt = newDataTable();
            dt.Columns.Add("Name1", typeof(int));
            dt.Columns.Add("Name2", typeof(object));
            dt.Columns.Add("Name3", typeof(object));
            for (int i = 0; i < 200; i++)
            {
                dt.Rows.Add( i, "款号" + Convert.ToString(i), "色号" +Convert.ToString(i));
            }
            gridControl1.DataSource = dt;
C#动态操作DataTable(新增行、列、查询行、列等)
public voidCreateTable()
        {
            //创建表
            DataTable dt = newDataTable();
            //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 voidCreateTable(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 voidSelectRowDataTable()
        {
            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 voidSelectColumnDataTable(DataTable dt)
        {
            //对DataTable筛选指定字段,并保存为新表
            DataTable dtNew = dt.DefaultView.ToTable(false, new string[] { "列名", "列名", "列名" });//这些列名,确保dt中存在,否则会报错误
        }
方法五:对DataTable进行排序设置(sort)
        public voidSortDataTable(DataTable dt)
        {
            dt.DefaultView.Sort = "id desc";//重新设置排序
            DataTable dtNew = dt.DefaultView.ToTable(); //保存在一张新表中
        }

免责声明:文章转载自《DataTable添加列和行的三种方法》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇软件体系架构的质量属性无法向Windows服务器复制粘贴文件下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

rootkit:实现隐藏进程

实现隐藏进程一般有两个方法: 1,把要隐藏的进程PID设置为0,因为系统默认是不显示PID为0的进程。 2,修改系统调用sys_getdents()。 Linux系统中用来查询文件信息的系统调用是sys_getdents,这一点可以通过strace来观察到,例如strace ls 将列出命令ls用到的系统调用,从中可以发现ls是通过getdents系统调用...

element ui设置表格表头高度和每一行的高度

.el-table__header tr, .el-table__header th {padding:0;height:30px;line-height:30px; }.el-table__body tr, .el-table__body td {padding:0;height:30px;line-hei...

sysbench对自装MySQL数据库进行基准测试

一、 安装sysbench wget https://packagecloud.io/install/repositories/akopytov/sysbench/script.rpm.sh chmod +x script.rpm.sh ./script.rpm.sh yum install -y sysbench 二、准备测试表 sysbench //...

【原创】大数据基础之Hive(5)性能调优Performance Tuning

1 compress & mr hive默认的execution engine是mr hive> set hive.execution.engine;hive.execution.engine=mr 所以针对mr的优化就是hive的优化,比如压缩和临时目录 mapred-site.xml <property>...

Html属性标签

 跑马灯 <marquee>...</marquee>普通卷动 <marquee behavior=slide>...</marquee>滑动 <marquee behavior=scroll>...</marquee>预设卷动 <marquee behavior=altern...

解决:Access模糊匹配查询查不到数据

今天遇到一个可笑的问题,直接操作Access的SQL语句: Select * from table where txtTitle like '%数据%' 匹配竟然无效。后来才发现在Access中模糊匹配应该用*代替% Select * from table where txtTitle like '*数据*' 狂晕。。。...