构造DataTable

DataTable dt=new DataTable("cart");
    DataColumn dc1
=new DataColumn("prizename",Type.GetType("System.String"));//生成列,列名
    DataColumn dc2
=new DataColumn("point",Type.GetType("System.Int16"));
    DataColumn dc3
=new DataColumn("number",Type.GetType("System.Int16"));
    DataColumn dc4
=new DataColumn("totalpoint",Type.GetType("System.Int64"));
    DataColumn dc5
=new DataColumn("prizeid",Type.GetType("System.String"));
    dt.Columns.Add(dc1);
    dt.Columns.Add(dc2);
    dt.Columns.Add(dc3);
    dt.Columns.Add(dc4);
    dt.Columns.Add(dc5);
//以上代码完成了DataTable的构架,但是里面是没有任何数据的
   for(int i=0;i<10;i++)
   
{
     DataRow dr
=dt.NewRow();
     dr[
"prizename"]="娃娃";
     dr[
"point"]=10;
     dr[
"number"]=1;
     dr[
"totalpoint"]=10;
     dr[
"prizeid"]="001";
     dt.Rows.Add(dr);
    }

//填充了10条相同的记录进去

有人会这么做
DataRow dr
=new DataRow();
  ..
dt.Rows.Add(dr);
这样是不行的,因为一个DataRow必定是属于一个DataTable的,不能凭空建立,就好比一条记录一定是属于一个表一样

又有人这么做
     DataRow dr
=dt.NewRow();
     dr[
"prizename"]="娃娃";
     dr[
"point"]=10;
     dr[
"number"]=1;
     dr[
"totalpoint"]=10;
     dr[
"prizeid"]="001";
   
for(int i=0;i<10;i++)
   
 {
          dt.Rows.Add(dr);
    }

这样做同样是错误的,因为DataTable已经有这条DataRow了,就好比一个表中不可能存在2条一样的记录,必须每次NewRow()

 

http://hi.baidu.com/feitianchong1/blog/item/df8301099abb7ed963d98636.html

http://hi.baidu.com/my_start/blog/item/34b18624dcaa4936c8955971.html

http://xslong.1986.blog.163.com/blog/static/228623482007784526629/

posted @ 2010-01-26 23:54  TiTi  阅读(933)  评论(0编辑  收藏  举报