ASP

本类阅读TOP10

·asp常用数据库连接方法和技巧
·无组件生成BMP验证码
·一些常用的辅助代码 (网络收藏)
·JavaScript实现的数据表格:冻结列、调整列宽和客户端排序
·VisualStudio.NET_2003及其 MSDN 下载地址
·ASP模拟MVC模式编程
·图片以二进制流输出到网页
·MD5加密算法 ASP版
·ASP.NET编程中的十大技巧
·改进 ASP 的字符串处理性能

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
(原创)怎么直接建立一个DataTable并且为之添加数据

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

比如在做购物车的时候我们需要建立一个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()





相关文章

相关软件