C# 创建DataTable

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;  //必须

方法1

DataTable dt = new DataTable("fruit");
dt.Columns.Add("ID", Type.GetType("System.Int32"));        //第1列
dt.Columns[0].AutoIncrement = true;       //自动增加
dt.Columns[0].AutoIncrementSeed = 1;      //起始为1
dt.Columns[0].AutoIncrementStep = 1;      //步长为1
dt.Columns.Add("水果", Type.GetType("System.String"));     //第2列
dt.Columns.Add("重量", Type.GetType("System.Double"));     //第3列
dt.Columns.Add("单价", Type.GetType("System.Decimal"));    //第4列

dt.Rows.Add(new object[] { null, "香蕉", 5, 2.5 });        // 第1行
dt.Rows.Add(new object[] { null, "苹果", 3, 3.5 });        // 第2行
dt.Rows.Add(new object[] { null, "李子", 1, 2.8 });        // 第3行
dt.Rows.Add(new object[] { null, "橙子", 2, 5.0 });        // 第4行
dt.Rows.Add(new object[] { null, "西瓜", 10, 1.2 });       // 第5行

// 查看数据
Console.WriteLine("ID" + "\t水果" + "\t重量" + "\t单价");
for (int i = 0; i < dt.Rows.Count; i++)
{
    DataRow r = dt.Rows[i];
    Console.WriteLine(r["ID"] + "\t" + r["水果"] + "\t" + r["重量"].ToString() + "\t" + r["单价"].ToString());
}
Console.ReadKey();

方法2

DataTable dt = new DataTable("fruit");
DataColumn dc = null;
dc = dt.Columns.Add("ID", Type.GetType("System.Int32"));        //第1列
dc.AutoIncrement = true;         //自动增加
dc.AutoIncrementSeed = 1;        //起始为1
dc.AutoIncrementStep = 1;        //步长为1

dc = dt.Columns.Add("水果", Type.GetType("System.String"));     //第2列
dc.AllowDBNull = false;    //第2列不能为空
dc = dt.Columns.Add("重量", Type.GetType("System.Double"));     //第3列
dc = dt.Columns.Add("单价", Type.GetType("System.Decimal"));    //第4列

DataRow newRow;
newRow = dt.NewRow();                                           // 第1行
newRow["水果"] = "香蕉";    //注释这一行会报错
newRow["重量"] = 2;
newRow["单价"] = 1.5;
dt.Rows.Add(newRow);

newRow = dt.NewRow();                                          // 第2行
newRow["水果"] = "苹果";
newRow["重量"] = 3.5;
newRow["单价"] = 2.0;
dt.Rows.Add(newRow);
// 查看数据
Console.WriteLine("ID" + "\t水果" + "\t重量" + "\t单价");
for (int i = 0; i < dt.Rows.Count; i++)
{
  DataRow r = dt.Rows[i];
  Console.WriteLine(r["ID"] + "\t" + r["水果"] + "\t" + r["重量"].ToString() + "\t" + r["单价"].ToString());
}
Console.ReadKey();

方法3

DataTable table = new DataTable();
//第1列
DataColumn priceColumn = new DataColumn();
priceColumn.DataType = System.Type.GetType("System.Decimal");
priceColumn.ColumnName = "price";
priceColumn.DefaultValue = 50;
//第2列
DataColumn taxColumn = new DataColumn();
taxColumn.DataType = System.Type.GetType("System.Decimal");
taxColumn.ColumnName = "tax";
taxColumn.Expression = "price * 0.045";  //表达式
//第3列
DataColumn totalColumn = new DataColumn();
totalColumn.DataType = System.Type.GetType("System.Decimal");
totalColumn.ColumnName = "total";
totalColumn.Expression = "price + tax";
// 将所有列添加到table上
table.Columns.Add(priceColumn);
table.Columns.Add(taxColumn);
table.Columns.Add(totalColumn);
// 第1行
DataRow row1 = table.NewRow();
table.Rows.Add(row1);
// 第2行
DataRow row2 = table.NewRow();
row2["price"] = 30;
table.Rows.Add(row2);

// 查看数据
Console.WriteLine("price" + "\ttax" + "\ttotal");
for (int i = 0; i < table.Rows.Count; i++)
{
    DataRow r = table.Rows[i];
    Console.WriteLine(r["price"] + "\t" + r["tax"].ToString() + "\t" + r["total"].ToString());
}
Console.ReadKey();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值