DataTable用法总结归纳

DataTable 用法归纳
2007-07-25 10:02
DataTable 用法归纳

一。创建一个内存表,下面的代码会用到它
DataTable      auto = new DataTable();

auto.Columns.Add("ID");

auto.Columns.Add("Name");

for(int i=1;i<=10;i++)

{

         auto.Rows.Add(new object[]{i,"baibaoqing"});

}

二。下面介绍DataTable对象经常使用的方法

          1. DataTable 的复制和克隆

           创建DataTable的完全副本(full copu 复制表的结构和数据),通过DataTable的Copy方法实现

           DataTable copy_Table=auto.Copy()

           for(int i=0;i<copy_Table.Rows.Length;i++)

           {

                  Response.Write("<script>alert("+copy_Table.Rows[i][0]+");</script>");

           }

输出的结果为从0到10 的数字

          有时需要复制DataTable 的表模式(表结果)而不复制数据,可以使用DataTable的Clone方法

           DataTable clone_Table=auto.Clone();

          在克隆了一个DataTable后,可能需要DataTable对象中的某些DataRow对象(行数据)复制到克隆的DataTabel 中,可以使用DataTable 的ImPortRow方法

          clone_Table.ImportRow(auto.Rows[0]);

         2.枚举DataTable

         通过Foreach循环遍历DataTable的行和列

         System.Text.StringBuilder      buffer=new System.Text.StringBuiler();

         foreach(DataColumn dc in auto.Colmns)

        {

                 buffer.Append(String.Format(“{0,15}”,dc.ColumnName));

        }

         buffer.Append("/r/t");

        foreach(DataRow dr in auto.Rows)

        {

                foreach(DataColumn dc in auto.Colmns)

               {

                buffer.Append(String.Format("{0,15}",dr[dc]));  
               }

               buffer.Append("/r/t");

}

textbox1.Text=buffer.ToString();

三. 使用DataView

          1. Sort排序

             DataView view=new DataView(auto);

             view.Sort="Make ASC,Year DESC";

             不过我很少使用DataView 的排序功能,我的作法是在SQL语句中使用Order by

           2. 使用RowFilter 精确查找

               DataView view=new DataView(auto);

               view.RowFilter="Make like 'AA%' and Year>2001";

              同样也可以在SQL语句中设置查询条件,看个人的习惯和实际的需要了。

            3 将DataView 导出到一个新表

             DataTable new_Table=view.ToTable("MyTable",true,"id","name");

             MyTable 新表的名称,true 表示显示不同的值,将相同的行删除(相当于Sql 的distinct),

           id 和name 为新表的列ID.

           4. 枚举DataView

            和枚举DataTabe大同小异

              System.Text.StringBuilder      buffer=new System.Text.StringBuiler();

         foreach(DataColumn dc in auto.Colmns)

        {

                 buffer.Append(String.Format(“{0,15}”,dc.ColumnName));

        }

         buffer.Append("/r/t");

        foreach(DataRowView dv in view)

        {

                foreach(DataColumn dc in auto.Colmns)

               {

                buffer.Append(String.Format("{0,15}",dv[dc]));  
               }

               buffer.Append("/r/t");

}

textbox1.Text=buffer.ToString();

另外在.net 2.0中DataTable对象可以处理XML文件,和DataSet一样,DataTable对象也有ReadXml和WriteXml 的方法,没有具体用过,有机会使用时再做总结。

------------------------------------------------------------------------------------------------------------------------------------------

通过DataTable获得表的主键

很多情形下我们需要知道表的主键是什么。在ADO.Net中提供了DataTable可以映射数据库的表。于是便可以利用DataTable的属性PrimaryKey,它是DataColumn[] 类型是一个数组。我们可以使用如下的代码

      DataColumn[] cols;
      cols = Table.PrimaryKey;
 //注意不是cols是DataColumn数组,不是DataColumn变量。这样做主要是为了处理联合主键的问题。
      for(int i = 0; i < cols.Length; i++)
      {
             MessageBox.Show(cols[i].ColumnName);
      }

 

按理这个问题就已经解决了,但是cols.Length却是0。原来在默认的情况下填充DataTable时并没有从数据库中取的主键的信息。如何获得主键呢?经过研究发现在填充Dataset的时候可以使用DataAdapter的MissingSchemaAction属性帮助我们解决这个问题,于是有如下的代码:

       //使用DataAdapter填充DataTable

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值