自定义datatable
Code
首先定义一个全局变量dataTable
public DataTable dt
{
get { return (DataTable)ViewState["dt"]; }
set { ViewState["dt"] = value; }
}
在首次加载页面的时候创建表的列
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataTable dt1 = new DataTable();
dt1.Columns.Add("Choose", typeof(string));
dt1.Columns.Add("IsRight", typeof(string));
dt1.Columns.Add("ID", typeof(string));
dt = dt1;
DataColumn[] dc = new DataColumn[1];
dc[0] = dt.Columns["ID"];
dt.PrimaryKey = dc;
}
}
点击button时添加记录
此时只是放在GridView1中,没有保存在数据库中
protected void btnAdd_Click(object sender, EventArgs e)
{
DataRow dr = dt.NewRow();
dr["Choose"] = txtChooseItem.Text;
dr["IsRight"] = cbRightItem.Checked ? true : false;
dr["ID"] = Guid.NewGuid().ToString();
dt.Rows.Add(dr);
dt.AcceptChanges();//这一句很重要,否则每次新增的纪录会覆盖久的纪录
if (dt.Rows.Count != 0)
{
GridView1.DataSource = dt;
ViewState["DataSource"] = dt;
GridView1.DataBind();
}
}
首先定义一个全局变量dataTable
public DataTable dt
{
get { return (DataTable)ViewState["dt"]; }
set { ViewState["dt"] = value; }
}
在首次加载页面的时候创建表的列
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataTable dt1 = new DataTable();
dt1.Columns.Add("Choose", typeof(string));
dt1.Columns.Add("IsRight", typeof(string));
dt1.Columns.Add("ID", typeof(string));
dt = dt1;
DataColumn[] dc = new DataColumn[1];
dc[0] = dt.Columns["ID"];
dt.PrimaryKey = dc;
}
}
点击button时添加记录
此时只是放在GridView1中,没有保存在数据库中
protected void btnAdd_Click(object sender, EventArgs e)
{
DataRow dr = dt.NewRow();
dr["Choose"] = txtChooseItem.Text;
dr["IsRight"] = cbRightItem.Checked ? true : false;
dr["ID"] = Guid.NewGuid().ToString();
dt.Rows.Add(dr);
dt.AcceptChanges();//这一句很重要,否则每次新增的纪录会覆盖久的纪录
if (dt.Rows.Count != 0)
{
GridView1.DataSource = dt;
ViewState["DataSource"] = dt;
GridView1.DataBind();
}
}
Code
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()
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()