第十四天 - ADO.NET 笔记

DataRow

作用:表示表中的实际数据。

DataRow的主要成员
成员作用
HasErrors、GetColumnsInError()、GetColumnError()、ClearErrors()和RowError返回一个布尔值,指示该行是否存在错误。如果有错误,GetColumnsInError()可以用来获取包含错误的成员,GetColumnError()获取错误的说明,而ClearError()用来清除该行的所有错误。RowErrors属性可以为错误设置一个自定义的文本说明
ItemArray通过一个对象数组来获取或设置此行的所有列值
RowState用来得到DataTable中当前DataRow的“状态”,值由RowState枚举定义
Table获取包含该DataRow的DataTable
AcceptChanges()和RejectChanges()这些方法提交或拒绝自上次调用AcceptChanges以来对该行进行的所有更改
BeginEdit()、EndEdit()和CancelEdit()同上
Delete()标记该行为待删除,调用AcceptChanges()后移除该行
IsNull获取一个值,指示指定的列是否包含空值

DataRow没有公共构造函数,不能直接创建该类型的实例:

static void FillDataSet(DataSet ds){
...
//现在为Inventory表增加一些行
DataRow carRow = inventoryTable.NewRow();
carRow["Make"] = "BMW";
carRow["Color"] = "Black";
carRow["PetName"] = "Hamlet";

carRow = inventoryTable.NewRow();
carRow[1] = "Saab";
carRow[2] = "Red";
carRow[3] = "Sea Breeze";
inventoryTable.Rows.Add(carRow);
}

RowState属性

用来指定表中一组行被修改、新增等时候。

DataRowState枚举的值
作用
Added该行已添加到DataRowCollection中,AcceptChanges()尚未调用
Deleted该行标记为通过DataRow的Delete()方法被删除,并且没有调用AcceptChanges()方法
Detached该行已被创建,但不属于任何DataRowCollection。DataRow在以下情况下立即处于此状态:创建之后,添加到集合中之前或者从集合中移除之后
Modified该行已被修改,AcceptChanges()尚未调用
Unchanged该行自上次调用AcceptChanges()以来尚未更改

DataRowVersion属性

作用
Current表示行的当前值,即使在做出改变后
DefaultDataRowState的默认值。对于Added、Modified或Deleted值的DataRowState,默认版本就是Current。对于Detached的DataRowState,版本就是Proposed
Original表示首次插入DataRow的值,或AcceptChanges()最后一次被调用后的值
Proposed表示调用BeginEdit()后当前正在被编辑的行的值

使用DataTable

DataTable主要成员
属性作用
CaseSensitive指示表中的字符串比较是否区分大小写,默认为false
ChildRelations获取此DataTable的子关系的集合
Constraints获取由该表维护的约束的集合
Copy()将某个DataTable的架构和数据复制到新实例中
DataSet获取此表所属的DataSet
DefaultView获取可能包括筛选视图或游标位置的表的自定义视图
ParentRelations获取该DataTable的父关系的集合
PrimaryKey获取或设置充当数据表主键的列的数组
TableName获取或设置表的名称,同样能通过构造参数指定这个属性

设置主键:

inventoryTable.PrimaryKey = new DataColumn[]{ inventoryTable.Columns[0] };

插入到DataSet中:

ds.Tables.Add(inventoryTable); 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值