DataColumn
DataColumn 是用于创建 DataTable 的列。下面示例使用不同技巧创建、配置一个列,并把它添加到一个 DataTable 中。
using System;
using System.Data.SqlClient;
using System.Data; namespace Test
{
class Program
{
static void Main(string[] args)
{
DataTable dt = new DataTable(); //在一个DataTable中添加一个DataColumn,并对列进行设置
DataColumn col1 = dt.Columns.Add();
col1.ColumnName = "Col1";
col1.DataType = typeof(int);
col1.DefaultValue = 0;
col1.Unique = true;
col1.AllowDBNull = false; //创建并设置一个DataColumn,并添加到DataTable中
DataColumn col2 = new DataColumn();
col2.ColumnName = "Col2";
col2.DataType = typeof(string);
col2.MaxLength = 50;
dt.Columns.Add(col2); //使用DataTable的Columns属性所提供的ColumnCollection对象的Add()方法
dt.Columns.Add("Col3", typeof(string)).MaxLength = 50; //创建多个DataColumn对象,使用DataTable的Columns属性所提供的ColumnCollection对象的AddRange()方法
DataColumn col4 = new DataColumn("Col4");
DataColumn col5 = new DataColumn("Col5");
dt.Columns.AddRange(new DataColumn[] { col4, col5 }); foreach (DataColumn col in dt.Columns)
{
Console.WriteLine(col.ColumnName);
}
Console.ReadKey();
}
}
}
DataColumn 构造函数有5个重载版本:
- DataColumn()
- DataColumn(string colName)
- DataColumn(string colName,Type dataType)
- DataColumn(string colName,Type dataType,string expression)
- DataColumn(string colName,Type dataType,string expression,MappingType mappingType)
其中:
colName:列名
dataType:列的数据类型,为Type类所支持的成员
expression:用于创建列的表达式
mappingType:指定了在转换为 XML 文档时,列是如何映射到元素或属性的,可以指定为 Element、Attribute、SimpleContent、Hidden
DataColumn 配置属性:
AllowDbNull:是否允许空值
AutoIncrement:是否自增
AutoIncrementSeed:自增的初始值
AutoIncrementStep:自增的递增值
ColumnMapping:当转换为 XML 时如何映射,可以指定为 Element、Attribute、SimpleContent、Hidden
ColumnName:列名
DataType:数据类型,为Type类所支持的成员
DateTimeMode:指定了DataSet 中 DateTime 列是如何进行串行化的,可以是 DataSetDateTime 枚举值之一
DefaultValue:默认值
Expression:用于计算列的值(或聚合值)的表达式
ExtendedProperties:与列相关联的用户自定义信息
MaxLength:文本类型的最大长度
Namespace:从包含该列的 DataTable 或 DataSet 对象读取和写入 XML 时该列的命名空间
Ordinal:该列在一个 DataColumnCollection 集合中的位置
Prefix:XML 的前缀,它是从包含该列的 DataTable 或 DataSet 对象读取和写入 XML 时该列的 XML 命名空间的别名
ReadOnly:该列是否只读
Unique:该列值是否唯一
DataColumnCollection 包含了一些 DataColumn 对象,DataTable 具有一个 DataColumnCollection 对象,可以通过 DataTable 的 Columns 属性来访问。我们使用这个属性来访问和管理 DataTable 中的列。DataColumnCollection 提供了一些成员,用于管理集合中的列。
DataColumnCollection 类的关键方法:
Add():向 DataColumnCollection 添加一个 DataColumn,这个方法有多个重载版本
AddRange():把一个 DataColumn 数组的成员复制到一个 DataColumnCollection 的尾部
CanRemove():返回一个标志,表示是否可以从 DataColumnCollection 删除一个 DataColumn 对象
Clear():清空 DataColumnCollection 的所有列
Contains():返回一个标志,表示 DataColumnCollection 是否包含了一个具有指定 ColumnName 的 DataColumn 对象
CopyTo():把 DataColumnCollection 的所有元素复制到一个一维 DataColumn 数组
IndexOf():返回一个基于0的索引,表示一个由 ColumnName 或 DataColumn 对象所指定的 DataColumn 在集合中第一次出现的位置,如果不存在这个列返回-1
Remove():删除一个由 ColumnName 或 DataColumn 对象所指定的 DataColumn 对象
RemoveAt():在 DataColumnCollection 中删除一个具有指定索引的 DataColumn 对象
下例显示了如何添加一个经过计算产生的列:
using System;
using System.Data.SqlClient;
using System.Data; namespace Test
{
class Program
{
static void Main(string[] args)
{
string connStr = @"Data Source=.;Initial Catalog=MyTest;Integrated Security=True;";
string sqlStr = "SELECT * FROM tb_SalesDetail";
SqlDataAdapter adp = new SqlDataAdapter(sqlStr, connStr);
DataTable dt = new DataTable();
adp.Fill(dt);
dt.Columns.Add(new DataColumn("Total", typeof(Decimal),"UnitPrice*(1-Disc)*Qty"));
foreach (DataRow row in dt.Rows)
{
Console.WriteLine("ID={0},UnitPrice={1},Disc={2},Qty={3},Total={4}", row["ID"], row["UnitPrice"], row["Disc"], row["Qty"], row["Total"]);
} Console.ReadKey();
}
}
}
运行结果如下:

下例显示了如何向一个显示父表数据的子 DataTable 添加一个列:
string connStr = @"Data Source=.;Initial Catalog=MyTest;Integrated Security=True;";
string sqlStr = @"SELECT * FROM tb_SalesHeader;SELECT * FROM tb_SalesDetail;";
DataSet ds = new DataSet();
SqlDataAdapter adp = new SqlDataAdapter(sqlStr, connStr); adp.TableMappings.Add("Table", "tb_SalesHeader");//列名
adp.TableMappings.Add("Table1", "tb_SalesDetail");//行 数据
adp.Fill(ds); //定义关系,关系的名称 父 子
DataRelation dr = new DataRelation("tb_SalesHeader_tb_SalesDetail", ds.Tables["tb_SalesHeader"].Columns["OrderID"], ds.Tables["tb_SalesDetail"].Columns["OrderID"]);
//获取用于将表链接起来并允许从父表浏览到子表的关系的集合。
ds.Relations.Add(dr);
ds.Tables["tb_SalesDetail"].Columns.Add("CustomerID", typeof(string), "Parent(tb_SalesHeader_tb_SalesDetail).CustomerID");
for (int i = ; i < ds.Tables["tb_SalesHeader"].Rows.Count; i++)
{
DataRow rowHeader = ds.Tables["tb_SalesHeader"].Rows[i];
Console.WriteLine("Header:OrderID={0},CustomerID={1}", rowHeader["OrderID"], rowHeader["CustomerID"]);
foreach (DataRow rowDetail in rowHeader.GetChildRows(dr))
{
Console.WriteLine("\tDeatil:OrderID={0},DetailID={1},CustomerID={2}", rowDetail["OrderID"], rowDetail["ID"], rowDetail["CustomerID"]);
}
} Console.ReadKey();
运行结果如下:

表达式列创建了一个经过计算的列,表示一条相关记录的信息。我们可以通过在父表列名前添加前缀 Parent. 引用父表记录中的一个列。如果由于多个数据关系的原因存在多个父表,就在括号内指定 DataRelation 的名称,把前缀 Parent(DataRelationName). 添加到父表的名称之前,因此上例中完全可以简写为:
ds.Tables["tb_SalesDetail"].Columns.Add("CustomerID",typeof(string), "Parent.CustomerID");
我们也可以通过在子表列名前加前缀 Child. 来引用一个子表记录。
此外,表达式列也支持下列聚合函数:
AVG:所有值的平均数
COUNT:值的数量
MAX:最大值
MIN:最小值
STDEV:所有值的统计标准差
SUM:所有值的和
VAR:所有值的统计方差
如果父记录不存在子记录,聚合函数将返回一个 null 。
DataColumn的更多相关文章
- 【MVVM DEV】DataColumn中的TextBox与ComboBox的并存
一.前言 在WPF编程中,有时候我们使用DataGrid会需要在一个DataColumn中既有TextBox,也要有ComboBox或者TextBlock等其他数据显示样式. 这个时候我们 ...
- DataTable DataRow DataColumn DataSet
1.DataTable 数据表(内存) 2.DataRow DataTable 的行 3.DataColumn DataTable 的列 4.DataSet 内存中的缓存
- 转:DataSet、DataTable、DataRow、DataColumn区别及使用实例
DataSet 表示数据在内存中的缓存. 属性 Tables 获取包含在 DataSet 中的表的集合. ds.Tables["sjxx"] DataTable 表示内存中数据的 ...
- 解决DataTable中的DataColumn类型默认为int类型时, 导致不能修改其列值为其他类型的解决办法
问题起因: 扔给数据库一条select * from [表名] , 得到一个DataTable, 发现有一列status状态的DataColumn的类型是int,然后我想换成字典表里的文字描述,然后就 ...
- DataSet、DataTable、DataRow、DataColumn区别及使用实例
DataSet 表示数据在内存中的缓存. 属性 Tables 获取包含在 DataSet 中的表的集合. ds.Tables["sjxx"] DataTable 表示内存中数据的 ...
- C#新DataColumn类Type生成的方法类型参数
DataColumn有的需要等级Type构造类型的参数,如以下: // // 摘要: // 使用指定列名称和数据类型初始化 System.Data.DataColumn 类的新实例. // // 參数 ...
- winform datagridview在添加全选checkbox时提示:不能设置 selected 或 selected 既不是表 Table 的 DataColumn 也不是 DataRelation。
在项目中,需要多选功能,于是在datagridview添加了一列DataGridViewCheckBoxColumn 在给datagridview绑定完数据集之后,对全选进行操作的时候,发现总报错,报 ...
- 在DataColumn.Expression把DateTime转换成String的问题
我在使用MySql5.1的数据库中,使用winForm的DataGridView要把数据库中全称DateTime格式,转换成Date格式,就是把日期时间转换成日期,不要时间.如‘2013-07-08 ...
- DataSet,DataTable,DataColumn,DataRow的常用操作
DataSet 这个玩意没什么好讲的,当ado.net查询出有多张表集合的数据返回时,这个时候就会使用到DataSet. DataTable //表之间直接赋值 dt2=dt1; 两者指向同一内存空间 ...
随机推荐
- Python函数系列-Random
import random i = int(input('输入第一个数:')) j = int(input('输入第二个数:')) l = int(input('输入需要产生的个数:')) k=0 w ...
- python笔记六:进程与线程
1.进程 1)调用unix/linux系统中的进程函数fork(),用法和linux相同,调用成功返回0,失败返回-1: import os print 'Process (%s) start...' ...
- centos 6.5 安装mysql 5.6.35--libc.so.6(GLIBC_2.14)(64bit)
[参考] http://blog.csdn.net/cpplang/article/details/8462768 http://www.linuxidc.com/Linux/2015-04/1160 ...
- poj3259(spfa)
自己的第一道spfa,纪念一下,顺便转载一下spfa的原理.先po代码: #include <iostream> #include <queue> using namespac ...
- functools.wraps 带参数的装饰器 多个装饰器装饰同一个函数
装饰器开发原则 : 开放封闭原则装饰器的作用 :在不改变原函数的调用方式的情况下,在函数的前后添加功能装饰器的本质 : 闭包函数 def wrapper(func): def inner(*args, ...
- 【BZOJ 2656】2656: [Zjoi2012]数列(sequence) (高精度)
2656: [Zjoi2012]数列(sequence) Time Limit: 2 Sec Memory Limit: 128 MBSubmit: 1499 Solved: 786 Descri ...
- 【UOJ #108】【APIO 2013】TOLL
http://uoj.ac/problem/108 好神的一道题啊. 原图边权互不相同是重点! 如果有一个点集,有两组边集,要求这两组边集的并集的最小生成树,可以对两组边集分别求一下最小生成树构成新的 ...
- PHP 笔记——PDO操作数据库
一.简介 PHP 5.1可使用轻量级的统一接口 PDO(PHP Data Object,PHP数据对象)来访问各种常见的数据库.而使用PDO只需要指定不同的 DSN(数据源名称)即可访问不同的数据 ...
- [BZOJ4651][NOI2016]网格(Tarjan)
下面直接给出结论,相关证明见官方题解. 1.若跳蚤数不超过1或仅有两只跳蚤且相邻,则答案为-1. 2.若跳蚤形成的连通块个数大于1,则答案为0. 3.若跳蚤之间建图存在割点,则答案为1. 4.否则为2 ...
- [Codeforces #514] Tutorial
Link: Codeforces #514 传送门 很简单的一场比赛打崩了也是菜得令人无话可说…… D: 一眼二分,发现对于固定的半径和点,能包含该点的圆的圆心一定在一个区间内,求出区间判断即可 此题 ...