【C#】【DataTable】如何自定义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条相同的记录进去

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


1.构造DataTable

DataTable dt= new DataTable(); 


DataColumn col = new DataColumn();
col.DataType = System.Type.GetType("System.String");
col.ColumnName = "KUNNR";
dt.Columns.Add(col);

col = new DataColumn();
col.DataType = System.Type.GetType("System.String");
col.ColumnName = "NAME1";
dt.Columns.Add(col);

col = new DataColumn();
col.DataType = System.Type.GetType("System.String");
col.ColumnName = "BUKRS";
dt.Columns.Add(col);

2.添加记录

DataRow dr=dt.NewRow();

dr["KUNNR"] = "客户编码";
dr["NAME1"] = "客户名称";
dr["BUKRS"] = "公司编码";

dt.Row.Add(dr);

posted @ 2021-10-29 16:14  大大龄码农  阅读(607)  评论(0编辑  收藏  举报