打开连接后,ADO.NET技巧使本地OLE DB向DATASOURCEINFO属性集调用IDBProperties.GetProperties来获取DBPROP_CONNECTIONSTATUS属性,这可能引起重新返回数据源。换句话说,检查State属性可能花费很大。
与XML集成
ADO.NET在数据集中提供了广泛的XML集成,并且暴露了一些SQL Server 2000及以上版本所提供的XML功能。你能使用SQLXML 3.0来访问SQL Server 2000及以上版本所提供的XML功能。下面是使用XML和ADO.NET技巧的一些和信息。
数据集与XML 数据集与XML紧密结合,提供了执行下面操作的能力,从XSD大纲载入数据集的大纲或者关系结构,从XML载入数据集的内容。
当没有提供大纲时根据XML文档的内容推断数据集的大纲,将数据集的大纲写成XSD大纲。 将数据集的内容写成XML。 ADO.NET技巧使用数据集同步访问数据的相关表现、使用XmlDataDocument访问数据的层次表现。
注意:你能使用这种同步在数据集的数据上应用XML功能(例如Xpath查询和XSLT变换),或提供所有的关系型视图,或者在保持原XML不变的情况下提供XML文档中的数据的子集。
大纲接口
当从XML文件中载入数据集时,你能从ADO.NET技巧中载入数据集的大纲,或者在载入数据前预先定义表和列。如果没有XSD大纲,并且你也不知道为XML文件的内容定义怎样的表和列,你能根据XML文档的结构推断大纲。
大纲推理作为迁移工具是有用的,但是由于推理过程有下面的限制,ADO.NET技巧只限于应用程序设计时使用: 推理大纲引入了附加的处理将降低应用程序的性能。 所有推理列的类型都是字符串型。 #t#
推理过程是不确定的。这就是说,它基于XML文件而不是预定的大纲。结果是你可能有两个XML文件,它们有相同的预定大纲,却因为它们的内容不同形成了两个完全不同的推理大纲。
为XML查询服务的SQL Server
如果你为XML查询返回ADO.NET技巧的结果,你能使用.NET框架组件SQL Server数据提供程序直接用SqlCommand.ExecuteXmlReader方法建立一个XmlReader。