分享
 
 
 

ADO.NET2.0跟ADO.NET3.0的一些新特性简要介绍

王朝c#·作者佚名  2008-05-30
窄屏简体版  字體: |||超大  

觉得很多人在写关于ASP.NET2.0的东东,很少有人写关于ADO.NET2.0的新特性。查找了一下MSDN,给大家介绍几点好了。(如果需要察看所有ADO.NET2.0的新特性,请查看

http://msdn2.microsoft.com/en-us/library/ex6y04yf.aspx)

Server Enumeration

用来枚举活动状态的SQL Server实例,版本需要在SQL2000及更新版本。使用的是SqlDataSourceEnumerator类

可以参考以下示例代码:

using System.Data.Sql;

class Program

{

static void Main()

{

// Retrieve the enumerator instance and then the data.

SqlDataSourceEnumerator instance =

SqlDataSourceEnumerator.Instance;

System.Data.DataTable table = instance.GetDataSources();

// Display the contents of the table.

DisplayData(table);

Console.WriteLine("Press any key to continue.");

Console.ReadKey();

}

private static void DisplayData(System.Data.DataTable table)

{

foreach (System.Data.DataRow row in table.Rows)

{

foreach (System.Data.DataColumn col in table.Columns)

{

Console.WriteLine("{0} = {1}", col.ColumnName, row[col]);

}

Console.WriteLine("============================");

}

}

}

DataSet Enhancements

新的DataTableReader类可以说是一个DataSet或者DataTable,的一个或者多个的read-only, forward-only的结果集。需要说明的是,DataTable返回的DataTableReader不包含被标记为deleted的行。

示例:

private static void TestCreateDataReader(DataTable dt)

{

// Given a DataTable, retrieve a DataTableReader

// allowing access to all the tables' data:

using (DataTableReader reader = dt.CreateDataReader())

{

do

{

if (!reader.HasRows)

{

Console.WriteLine("Empty DataTableReader");

}

else

{

PrintColumns(reader);

}

Console.WriteLine("========================");

} while (reader.NextResult());

}

}

private static DataTable GetCustomers()

{

// Create sample Customers table, in order

// to demonstrate the behavior of the DataTableReader.

DataTable table = new DataTable();

// Create two columns, ID and Name.

DataColumn idColumn = table.Columns.Add("ID", typeof(int));

table.Columns.Add("Name", typeof(string));

// Set the ID column as the primary key column.

table.PrimaryKey = new DataColumn[] { idColumn };

table.Rows.Add(new object[] { 1, "Mary" });

table.Rows.Add(new object[] { 2, "Andy" });

table.Rows.Add(new object[] { 3, "Peter" });

table.Rows.Add(new object[] { 4, "Russ" });

return table;

}

private static void PrintColumns(DataTableReader reader)

{

// Loop through all the rows in the DataTableReader

while (reader.Read())

{

for (int i = 0; i < reader.FieldCount; i++)

{

Console.Write(reader[i] + " ");

}

Console.WriteLine();

}

}

Binary Serialization for the DataSet

关于这点linkcd已经写过一篇性能测试的文章:.Net 2.0 下Data Container性能比较: Binary Serialize Dataset vs Custom Classes

DataTable as a Stand-Alone Object

很多以前DataSet的方法,现在可以用DataTable直接使用了

Create a DataTable from a DataView

现在可以从DataView返回一个DataTable了,两者基本是一样的,当然你也可以有选择性的返回,比如说返回distinct rows

New DataTable Loading Capabilities

DataTables跟DataSets现在提供一个新的Load方法,可以直接把DataReader中的数据流载入到DataTable中,当然你也可以对如何Load做一些选择。

以上是ADO.NET2.0的一些特性,你使用.NET2.0进行开发,就可以使用这些特性。

更激动人心的在于ADO.NET3.0的一些特性.

有文章介绍了一些ADO.NET3.0 AUGUT CTP的一些特性:

The ADO.NET Entity Framework

The Entity Data Model (EDM),实体数据模型,开发者可以以更高的抽象层次来设计数据模型

一个很牛的client-views/mapping引擎,用来映射(map to and form)存储结构(store schemas )

完全支持使用Entity SQL跟LINQ( 这东西现在出现频率还挺高的哦,也挺好玩的一个东东)查询EDM schemas

.....

LINQ(AUGUST CTP):

LINQ to Entities: 使用LINQ查询EDM schemas

LINQ to DataSet: 对一个或者多个DataTable进行LINQ查询

都是很期待的技术,Enjoy it!:)

http://www.cnblogs.com/wdxinren/archive/2006/09/04/494260.html

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有