`

C# DataSet和DataTable详解(二)

    博客分类:
  • .net
阅读更多
1、DataSet
①、属性
CaseSensitive:用于控制DataTable中的字符串比较是否区分大小写。

DataSetName:当前DataSet的名称。如果不指定,则该属性值设置为"NewDataSet".如果将DataSet内容写入XML文件,DataSetName是XML文件的根节点名称。
DesignMode:如果在设计时使用组件中的DataSet,DesignMode返回True,否则返回False.

HasErrors:表示DataSet中的DataRow对象是否包含错误。如果将一批更改提交给数据库并将DataAdapter对象的ContinueUpdateOnError属性设置为True,则在提交更改后必须检查DataSet的HasErrors属性,以确定是否有更新失败。

NameSpace和Prefix:指定XML命名空间和前缀

Relations:返回一个DataRelationCollection对象。

Tables:检查现有的DataTable对象。通过索引访问DataTable有更好的性能。

②、方法
AcceptChanges和RejectChanges:接受或放弃DataSet中所有挂起更改。调用AcceptChanges时,RowState属性值为Added或Modified的所有行的RowState属性都将被设置为UnChanged.任何标记为Deleted的DataRow对象将从DataSet中删除。调用RejectChanges时,任何标记为Added的DataRow对象将会被从DataSet中删除,其他修改过的DatRow对象将返回前一状态。

Clear:清除DataSet中所有DataRow对象。该方法比释放一个DataSet然后再创建一个相同结构的新DataSet要快。

Clone和Copy:使用Copy方法会创建与原DataSet具有相同结构和相同行的新DataSet.使用Clone方法会创建具有相同结构的新DataSet,但不包含任何行。

GetChanges:返回与原DataSet对象具有相同结构的新DataSet,并且还包含原DataSet中所有挂起更改的行。

GetXml和GetXmlSchema:使用GetXml方法得到由DataSet的内容与她的架构信息转换为XML格式后的字符串。如果只希望返回架构信息,可以使用GetXmlSchema.

HasChange:表示DataSet中是否包含挂起更改的DataRow对象。

Merge:从另一个DataSet、DataTable或现有DataSet中的一组DataRow对象载入数据。

ReadXml和WriteXml:使用ReadXml方法从文件、TextReader、数据流或者XmlReader中将XML数据载入DataSet中。

Reset:将DataSet返回为未初始化状态。如果想放弃现有DataSet并且开始处理新的DataSet,使用Reset方法比创建一个DataSet的新实例好。

③、事件
MergeFailed:在DataSet的Merge方法发生一个异常时触发。

2、DataTable
①、属性

②、方法

③、事件

ColumnChanged:在列的内容被改变之后触发

ColumnChangding:在列的内容被改变之前触发

RowChanged,RowChanging,RowDeleted,RowDeleting.

3、DataColumn

①、属性

4、DataRow

①、属性

HasError:确定行是否包含错误。

Item:通过指定行的列数,列的名称或DataColumn对象本身,访问列的内容。

ItemArray:获取或设置行中所有列的值。

RowError:返回一个包含行错误信息的字符串。

RowState:返回DataRowState枚举中的值来表示行的当前状态。

Table:返回DataRow对象所在的DataTable.

②、方法

AcceptChanges和RejectChanges:提交和放弃挂起更改。

BeginEdit、CancelEdit、EndEdit

ClearErrors:清除DataRow中所有的错误。

Delete:Delete方法实际上并不从DataRow表的Row集合中删除该DataRow.当调用DataRow对象的Delete方法时,ADO.NET将该行标记为删除,之后调用SqlDataAdapter对象的Update方法来删除其在数据库中对应的行。

如果希望彻底删除DataRow,可以调用Delete方法,接着再调用它的AccepteChanges方法,还可以使用DataRowCollection对象的Remove方法完成相同的任务。

3 如何遍历DataSet

[code="java"]foreach(DataTable dt in dataSet.Tables)
foreach(DataRow dr in dt.Rows)
foreach(DataColumn dc in dr.Table.Columns)
Console.WriteLine(dr[dc]);


浅谈DataSet 的用法
DataSet是ADO.NET开发人员为方便数据处理开发出来的,是数据的集合,是为解决DataReader的缺陷设计的,DataReader数据处理速度快,但它是只读的, 而且一旦移到下一行,就不能查看上一行的数据,DataSet则可以自由移动指针。DataSet的数据是与数据库断开的。DataSet还可用于多层应用程序中,如果应用程序运行在中间层的业务对象中来访问数据库,则业务对象需将脱机数据结构传递给客户应用程序。

  DataSet的功能:浏览、排序、搜索、过滤、处理分级数据、缓存更改等。还可以与XML数据互换。DataSet中可包括多个DataTable,可将多个查询结构存到一个DataSet中,方便操作,而DataTable中又包括多个DataRow、DataColumn,可通过这些DataRow、DataColumn来查看、操作其中的数据,而需将操作结果返回给数据库的话,则可以调用DataAdapter的Update方法。

  DataSet的操作:


[code="java"]DataSet ds=new DataSet();
DataTable dt=new DataTable("newTable");
ds.Tables.Add(dt);

DataSet ds=new DataSet();
DataTable dt=ds.Tables.Add("newTable");
上述两种方法都可以在DataSet中添加一个DataTable,看需要而进行选择。添加DataTable后,需向其中添加行和列。


[code="java"]DataSet ds=new DataSet();
DataTable dt=ds.Tables.Add("newTables");
DataColumn col=dt.Columns.Add("newColumn",typeof(int));
col.AllowDBNull=false;
col.MaxLength=4;
col.Unique=true;


上述代码向DataSet中的DataTable中添加名为”newColumn”,类型为int且不为空,最大长度为4和唯一性为真的列。

dt.PrimaryKey=new DataColumn[]{dt.Columns["ID"]}
这段代码是继续上面代码的,为一个DataTable中添加一个主键列,主键列是一个数据组,如有多个主键,只需在数组中添加一个列即可。如下:

dt.PrimaryKey=new DataColumns[]{dt.Columns["OrderID"],dt.Columns["ProductID"]}
添加外键:


[code="java"]ForeignKeyConstraint fk;
fk=new ForeignKeyConstraint(ds.Tables["Customers"].Columns["CustomerID"],ds.Tables["Orders"].Columns["CustomerID"]);
ds.Tables["Orders"].Constraints.Add(fk);

//上述代码假如已经为Cusomers表和Orders创建了主键,此句为添加外键约束。
上述是根据Customers表和Orders表的CustomerID来创建约束。

下面介绍修改DataRow中的内容:


[code="java"]DataRow dr=ds.Tables["Customer"].Rows.Find("ANTON");
if(dr==null)

else
{
dr.BeginEdit();
dr["CompanyName"]="newValue";
dr["ContactName"]="newValue2";
dr.EndEdit();
}

//上面代码通过Row集合的Find方法来在DataTable中的行进行定位,找到"ANTON"行,再修改"ANTON"行中CompanyName列和ContactName列的值。通过BeginEdit和EndEdit来缓存对行的修改,还可调用 CancelEdit为取消修改。
判断某列是否为空值:



[code="java"]DataRow dr=ds.Tables["Customers"].Rows.Find("aaa");
if(dr.IsNull("ContactName");
..
else
dr["ContactName"]=DBNull.Value

//这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。
删除DataRow:

有两种方法可以删除DataRow,Delete方法和Remove方法和RemoveAt方法。其区别是Delete方法实际上不是从DataTable中删除掉一行,而是将其标志为删除,仅仅是做个记号,而Remove方法则是真正的从DataRow中删除一行,RemoveAt方法是根本行的索引来删除。列:

DataRow dr=ds.Tables["table"].Rows.Find("a");
ds.Tables["table"].Remove(dr);

ds.Tables["table"].Remove(index);
//dr 为"a"所在的行,查出后将其删除,index为 "a"所在的索引号。关于DataSet中的其用法,参照MSDN



DataRow dr=ds.Tables["Customers"].Rows.Find("aaa");
if(dr.IsNull("ContactName");
..
else
dr["ContactName"]=DBNull.Value
//这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。

using System.Data;
using System;
using System.Windows.Forms;
class DataT{
static DataTable dt;// = new DataTable();
static DataSet ds;
static void method1(){
dt = new DataTable("Name");
ds = new DataSet();
dt.Columns.Add(new DataColumn("ID", typeof(Int32)));
dt.Columns.Add(new DataColumn("Name", typeof(string)));
dt.Columns.Add(new DataColumn("Sex", typeof(string)));
dt.Columns.Add(new DataColumn("Addr", typeof(string)));
}
static void add(int id,string name,string sex,string addr){
DataRow dr = dt.NewRow();
dr["id"] = id;
dr["Name"] = name;
dr["Sex"] = sex;
dr["Addr"] = addr;
dt.Rows.Add(dr);


}
static void Main(){
DataT DT = new DataT();
method1();
add(100,"Join","Male","北京");
add(101,"Lily","feMale","北京");
add(102,"JIM","Male","北京");
ds.Tables.Add(dt);
foreach(DataRow dr in dt.Rows){
//MessageBox.Show(dr["ID"].ToString() + " " + dr["Name"].ToString() + " " + dr["Sex"].ToString() + " " +
// dr["Addr"].ToString(),"Message");
Console.WriteLine(dr["ID"].ToString() + " " + dr["Name"].ToString() + " " + dr["Sex"].ToString() + " " +
dr["Addr"].ToString());

}
try{
foreach(DataTable dt2 in ds.Tables)
foreach(DataRow dr in dt2.Rows)
Console.WriteLine(dr["ID"].ToString() + " " + dr["Name"].ToString() + " " + dr["Sex"].ToString() + " " +
dr["Addr"].ToString());
}catch(Exception ex){
Console.WriteLine("dkfjksdjfk");
}
}

  TOP


分享到:
评论

相关推荐

    C# DataSet和DataTable详解

    C# DataSet和DataTable详解 在C#编程中,DataSet和DataTable是两个非常重要的类,它们都是ADO.NET中数据访问的核心组件。下面,我们将详细探讨这两个类的使用和特性。 创建DataSet对象 DataSet是ADO.NET中的一种...

    C#_DataSet和DataTable详解

    ### C#中DataSet和DataTable详解 在C#的.NET框架中,`DataSet`和`DataTable`是处理数据集的关键组成部分,它们提供了强大的功能来存储、操作和管理数据,尤其是在与数据库交互时。以下是对这两个核心概念的深入解析...

    详解C#的DataSet和DataTable

    详解 C# 的 DataSet 和 DataTable DataSet 和 DataTable 是 C# 中两个非常重要的数据结构,广泛应用于数据存储、数据处理和数据显示等方面。本文将详细介绍 DataSet 和 DataTable 的概念、关系、区别和使用方法。 ...

    C__DataSet和DataTable详解

    在C#编程中,DataSet和DataTable是.NET Framework中用于处理和管理数据的重要组件。它们主要用于离线数据操作,例如在内存中存储和操作来自数据库的数据。以下是对这两个概念的详细解释。 **1. DataSet** DataSet是...

    C#中DataSet的用法(很详细)

    在C#编程中,DataSet是ADO.NET框架中的一个重要组件,它是内存中数据的容器,能够离线存储和处理数据。DataSet不仅包含多个DataTable,用于存储实际的数据,还提供了丰富的功能,如浏览、排序、搜索、过滤和缓存更改...

    将datatable里的数据导出DBF文件

    上述步骤展示了如何在C#中将`DataTable`中的数据导出至DBF文件的具体实现方法。这种方法适用于需要将数据保存到FoxPro数据库或其他兼容DBF格式的应用场景。值得注意的是,在实际操作过程中还需要考虑到异常处理、...

    DataSet 转化为List的通用方法

    #### 二、通用转换方法详解 通用转换方法的核心在于能够自动识别`DataSet`中`DataTable`的列类型,并将其转换为相应的`List<T>`类型,其中`T`为具体的业务实体类。以下是对代码片段的详细解析: ```csharp public ...

    XML与DataTable相互转换

    ### XML与DataTable相互转换知识点详解 #### 一、概述 在.NET框架中,XML与`DataTable`之间的相互转换是一项常用的技术。它可以帮助开发者在不同场景下灵活地处理数据,例如在网络传输、数据存储或者与其他系统...

    C# SqlDataAdapter与DataSet的使用

    ### C# 中 SqlDataAdapter 与 DataSet 的使用详解 #### 一、引言 在 C# 开发中,数据访问层的设计尤为重要。其中,`SqlDataAdapter` 和 `DataSet` 是两个非常重要的概念,它们可以帮助开发者实现从数据库到应用程序...

    DataGridView 详解 使用技巧 添加、修改、删除数据操作

    今天,我们将深入探讨 DataGridView 的使用技巧,包括添加、修改、删除数据操作,以及如何使用 DataSet 和 DataTable 详解 DataGridView 的使用。 使用 DataSet 和 DataTable 在实际开发中,我们经常使用 DataSet ...

    C# DataTable数据表的操作

    ### C# DataTable 数据表的操作详解 #### 一、概述 在C#开发中,`DataTable` 是一个非常重要的数据结构,它提供了类似数据库表格的功能,用于存储和操作数据集。本文将详细介绍如何在C#中操作`DataTable`,特别是...

    DataSet用法详解

    ### DataSet用法详解 #### 一、概述 `DataSet`是ADO.NET中非常重要的组成部分,它主要用于存储和操作从数据库中获取的数据。`DataSet`是一个内存中的缓存数据存储器,能够脱离数据库独立存在,因此被称为离线数据...

    C#版ADO.NET实践技巧

    接着,"C#+DataSet和DataTable详解"部分将深入介绍这两个组件的使用。DataSet是.NET框架中的一个内存缓存,可以容纳多个DataTable,允许离线操作数据。DataTable则是一个在内存中的表格,类似于数据库的表。这部分...

    C# WinForm开发控件详解

    WinForms可以与各种数据库进行交互,例如使用ADO.NET库连接SQL Server,通过DataSet、DataTable和DataAdapter对象来操作数据。 总结,C# WinForm开发控件详解的课程将涵盖以上各个重要知识点,通过学习,开发者可以...

    把DataView转换成DataTable

    在.NET框架中,`DataView` 和 `DataTable` 都是用于处理数据集(DataSet)的重要组成部分。通常情况下,`DataTable` 是一个内存中的二维表格,它提供了类似数据库表的功能,而 `DataView` 则提供了一种灵活的方式来...

    一个基于C#+Silverlight实现的Dataset Surrogate程序例子源码

    标题提到的是"一个基于C#+Silverlight实现的Dataset Surrogate程序例子源码",这表明我们讨论的是一段使用C#编程语言和Silverlight技术编写的源代码,具体是关于Dataset Surrogate的实现。Dataset Surrogate是一种在...

    ACCP5.0C#详解

    使用DataSet、DataTable等组件,可以实现离线数据处理。 最后,随着.NET框架的不断演进,C#也不断引入新的特性,如async/await异步编程模型、LINQ(Language Integrated Query)集成查询、以及C# 9.0及更高版本的新...

    C#ADO电子帮助文档 详细介绍.rar

    5. **DataSet** 和 **DataTable**:DataSet是一个内存中的数据集合,可以包含多个DataTable。DataTable则代表单个表格,包含列和行数据。它们不直接与数据库连接,可以进行离线操作。 **C#与ADO.NET结合** 在C#中...

Global site tag (gtag.js) - Google Analytics