zoukankan      html  css  js  c++  java
  • (原创)怎么直接建立一个DataTable并且为之添加数据

    比如在做购物车的时候我们需要建立一个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条相同的记录进去

    如果做购物车的话,可以把它添加到Session或者Cookie中去,比如
    Session["cart"]=dt;
    取出来的时候
    if(Session["cart"]!=null)
    {
        DataTable dt=(DataTable)Session["cart"];
    }


    有人会这么做
    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()

  • 相关阅读:
    [转]使用Java Mission Control进行内存分配分析
    JDE开发端安装问题(JDE初步卸载重装)
    JDE开发端安装笔记
    [转]JDE910--jas.ini参数说明
    [转]十个常见的缓存使用误区及建议
    JDE910笔记2--OMW项目建立及简单使用
    JDE910笔记1--基础介绍及配置
    [转] 编程之美--字符串移位包含的问题
    关于JDBC
    [转]何时使用委托而不使用接口(C# 编程指南)
  • 原文地址:https://www.cnblogs.com/lovecherry/p/125513.html
Copyright © 2011-2022 走看看