System.Web
2.0.0.0
System.Web.UI.HierarchicalDataSourceControl
System.ComponentModel.IListSource
System.Web.UI.IDataSource
System.Web.UI.PersistChildren(false)
System.Web.UI.ParseChildren(true)
System.ComponentModel.DefaultEvent("Transforming")
System.ComponentModel.DefaultProperty("DataFile")
System.ComponentModel.Designer("System.Web.UI.Design.WebControls.XmlDataSourceDesigner, System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.ComponentModel.Design.IDesigner")
In this topic:
-
Introduction
-
Sources of XML Data
-
Updating XML Data
-
Specifying an XSL Transformation
-
Filtering using an XPath Expression
-
Caching
-
Additional Features
-
Data View Object
-
Declarative Syntax
Introduction
The control is a data source control that presents XML data to data-bound controls. The control can be used by data-bound controls to display both hierarchical and tabular data. The control is typically used to display hierarchical XML data in read-only scenarios. Because the control extends the class, it works with hierarchical data. The control also implements the interface and works with tabular, or list-style, data.
For security purposes, none of the control properties are stored in view state. Since it is technically possible to decode the contents of view state on the client, storing sensitive information about the data structure or its contents could expose you to an information disclosure threat. Note that if you need to store information such as property in view state, you can enable encryption to protect the contents by setting on the @ Page directive.
Page developers use the control to display XML data using data-bound controls.
Sources of XML Data
The typically loads XML data from an XML file, which is specified by the property. XML data can also be stored directly by the data source control in string form using the property. If you want to transform the XML data before it is displayed by a data-bound control, you can provide an Extensible Stylesheet Language (XSL) style sheet for the transformation. As with the XML data, you typically load the style sheet from a file, indicated by the property, but you can also store it in string form directly using the property.
Updating XML Data
The control is commonly used in read-only data scenarios where a data-bound control displays XML data. However, you can also use the control to edit XML data. To edit the XML data, call the method to retrieve an object that is an in-memory representation of the XML data. You can use the object model exposed by the and objects it contains or use an XPath filtering expression to manipulate data in the document. When you have made changes to the in-memory representation of the XML data, you can save it to disk by calling the method.
There are some restrictions to the editing capabilities of the control:
-
The XML data must be loaded from an XML file that is indicated by the property, not from inline XML specified in the property.
-
No XSLT transformation can be specified in the or properties.
-
The method does not handle concurrent save operations by different requests. If more than one user is editing an XML file through the , there is no guarantee that all users are operating with the same data. It is also possible for a operation to fail due to these same concurrency issues.
Specifying an XSL Transformation
A common operation performed with XML data is transforming it from one XML data set into another. The control supports XML transformations with the and properties, which specify an XSL style sheet to apply to XML data before it is passed to a data-bound control, and the property, which enables you to supply dynamic XSLT style sheet arguments to be used by an XSL style sheet during the transformation. If you specify an XPath filtering expression using the property, it is applied after the transformation takes place.
The class uses the deprecated class to perform XSL transformations. If you want to use style sheet features that were introduced after the class was deprecated, apply the transforms manually by using the class.
Filtering using an XPath Expression
By default, the control loads all the XML data in the XML file identified by the property or found inline in the property, but you can filter the data using an XPath expression. The property supports an XPath-syntax filter that is applied after XML data is loaded and transformed.
Caching
For performance purposes, caching is enabled for the control by default. Opening and reading an XML file on the server every time a page requested can reduce the performance of your application. Caching lets you reduce the processing load on your server at the expense of memory on the Web server; in most cases this is a good trade-off. The automatically caches data when the property is set to true, and the property is set to the number of seconds that the cache stores data before the cache is invalidated. You can use the to further fine-tune the caching behavior of the data source control.
Additional Features
The following table lists additional features that are supported by the control.
-
Capability
Description
-
Sorting
Not supported by the control.
-
Filtering
The property can be used to filter the XML data using an appropriate XPath expression.
-
Paging
Not supported by the control.
-
Updating
Supported by manipulating the directly and then calling the method.
-
Deleting
Supported by manipulating the directly and then calling the method.
-
Inserting
Supported by manipulating the directly and then calling the method.
-
Caching
Enabled by default, with the property set to 0 (infinite) and the property set to .
Data View Object
Because the control supports data-bound controls that display hierarchical data as well as controls that display tabular data, the data source control supports multiple types of data source view objects on its underlying XML data. The control retrieves a single named object when used with a data-bound control that displays tabular data. The method identifies this single named view. When used with a data-bound control that displays hierarchical data, the control retrieves an for any unique hierarchical path passed to the method.
Declarative Syntax
<asp:XmlDataSource
CacheDuration="string|Infinite"
CacheExpirationPolicy="Absolute|Sliding"
CacheKeyDependency="string"
DataFile="string"
EnableCaching="True|False"
EnableTheming="True|False"
EnableViewState="True|False"
ID="string"
OnDataBinding="DataBinding event handler"
OnDisposed="Disposed event handler"
OnInit="Init event handler"
OnLoad="Load event handler"
OnPreRender="PreRender event handler"
OnTransforming="Transforming event handler"
OnUnload="Unload event handler"
runat="server"
SkinID="string"
TransformArgumentList="string"
TransformFile="string"
Visible="True|False"
XPath="string"
>
<Data>string</Data>
<Transform>string</Transform>
</asp:XmlDataSource>
Represents an XML data source to data-bound controls.
Constructor
To be added.
Creates a new instance of the class.
2.0.0.0
Property
System.ComponentModel.DefaultValue(0)
System.Int32
To be added.
The control automatically caches data when the following applies:
-
The property is set to true.
-
The property is set to a value greater than 0, which indicates the number of seconds that the cache stores data before the cache is invalidated.
Any change to the property or the contents of the file that contains the XML data causes the cache to be invalidated.
By default, the property is set to 0, which indicates an indefinite cache, and the data source will cache data until the XML file that it depends on is changed.
The behavior of the cache is governed by a combination of the duration and the setting. If is set to , the control caches data on the first data retrieval operation, holds it in memory for the amount of time specified by , and invalidates it after the time has lapsed. The cache is then refreshed upon the next operation. If is set to , the data source control caches data on the first data retrieval operation, but resets the time window that it holds the cache for upon each subsequent operation. The cache will only expire if there is no activity for a time equal to the since the last data retrieval.
Gets or sets the length of time, in seconds, that the data source control caches data it has retrieved.
2.0.0.0
Property
System.ComponentModel.DefaultValue(System.Web.UI.DataSourceCacheExpiry.Absolute)
System.Web.UI.DataSourceCacheExpiry
To be added.
The behavior of the cache is governed by a combination of the and settings. If the is set to , the caches data on the first data retrieval operation, holds it in memory for the amount of time specified by , and invalidates it after the time has lapsed. The cache is then refreshed upon the next operation. If the is set to , the data source control caches data on the first data retrieval operation, but resets the time window that it holds the cache for upon each subsequent operation. The cache will expire only if there is no activity for a time equal to the since the last data retrieval.
Gets or sets the cache expiration policy that is combined with the cache duration to describe the caching behavior of the cache that the data source control uses.
2.0.0.0
Property
System.ComponentModel.DefaultValue("")
System.String
To be added.
The control supports data caching. While data is cached, the retrieves data from the cache rather than from the underlying data file. When the cache expires, it retrieves data from the underlying file and re-caches the data.
You can set the property to create a dependency between all cache entries created by the control and the key. You can programmatically invalidate all the cache entries at any time by expiring the key.
Because of the properties used to create the , it is possible that multiple controls can use the same cache in scenarios where they load the same data from the same XML file and transform file and have the same and set.
Gets or sets a user-defined key dependency that is linked to all data cache objects created by the data source control. All cache objects explicitly expire when the key expires.
2.0.0.0
Property
System.ComponentModel.Editor("System.ComponentModel.Design.MultilineStringEditor,System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")
System.Web.UI.PersistenceMode(System.Web.UI.PersistenceMode.InnerProperty)
System.ComponentModel.DefaultValue("")
System.String
To be added.
In declarative scenarios, the property is specified as a multiline inner property of the object. An inner property is compatible with XML data, because it enables you to format the XML data in any way and ignore character padding issues, such as padding quote characters.
If both the and properties are set, the property takes precedence and the data in the XML file is used instead of the XML data specified in the property.
If you change the value of the property, the event is raised. If caching is enabled and you change the value of , the cache is invalidated.
Gets or sets a block of XML data that the data source control binds to.
2.0.0.0
Property
System.ComponentModel.Editor("System.Web.UI.Design.XmlDataFileEditor, System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")
System.ComponentModel.DefaultValue("")
System.String
To be added.
If both the and properties are set, the property takes precedence and the data in the XML file is used instead of the XML data specified in the property.
If you change the value of the property, the event is raised. If caching is enabled and you change the value of , the cache is invalidated.
Specifies the file name of an XML file that the data source binds to.
2.0.0.0
Property
System.ComponentModel.DefaultValue(true)
System.Boolean
To be added.
The control automatically caches data when the property is set to true. By default, the property is set to 0, which indicates an indefinite cache, and the data source will cache data until the XML file that it depends on is changed. If you set the property to a value greater than 0, the cache stores data for that many seconds before retrieving a fresh set.
If the property is set to true and the property is set, the cache entries are not automatically invalidated when the parameters change in the transforms argument list. In that case, you must write code to invalidate the cache by setting the property.
Gets or sets a value indicating whether the control has data caching enabled.
2.0.0.0
Method
System.Web.UI.HierarchicalDataSourceView
You can call the method to retrieve a object associated with the control. If you specify value, the control returns a data source view object that represents the view on the node identified by , along with all its child nodes. If you set to , the control checks the property to determine the root node from which to build the data source view. If the property is set, the control uses it to return a data source view in the same way the expression is used. If the property is not set, the control returns a view of all the data nodes in the XML data.
Gets the data source view object for the control. The parameter can be an XPath expression.
Returns an object that represents a single view of the data starting with the data node identified by .
An XPath expression that identifies a node from which the current hierarchical view is built.
2.0.0.0
Method
System.Xml.XmlDocument
Use the method for direct access to an in-memory representation of the underlying XML data.
You can manipulate the returned object and then call to persist your changes to the XML file specified by the property. Several requirements must be met before the object can be saved successfully. For more information, see the method.
Loads the XML data into memory, either directly from the underlying data storage or from the cache, and returns it in the form of an object.
An object that represents the XML specified in the property or in the file identified by the property, with any transformations and queries applied.
2.0.0.0
Method
System.Void
Raising an event invokes the event handler through a delegate. For more information, see Consuming Events.
The method also allows derived classes to handle the event without attaching a delegate. This is the preferred technique for handling the event in a derived class.
Raises the event before the control performs an XSLT transformation on its XML data.
An that contains the event data.
2.0.0.0
Method
System.Void
While the control is typically used in read-only data-binding scenarios, you can use the control to edit XML data in the underlying XML data file. In these scenarios, XML data is loaded from an XML file by the control. You modify the in memory using the method, and then save to the XML data file by calling the method. This editable XML scenario is possible when the following conditions are met:
-
The XML data is loaded from an XML file indicated by the property, not from inline XML data specified in the property.
-
No XSLT transformation is specified in the or properties.
The method does not handle concurrent save operations by different requests. If more than one user is editing an XML file through the control, there is no guarantee that all users are operating with the same data. It is also possible for a operation to fail due to these same concurrency issues.
Saves the XML data currently held in memory by the control to disk if the property is set.
2.0.0.0
Property
2.0.0.0
System.Boolean
To be added.
This member is an explicit interface member implementation. It can be used only when the instance is cast to the interface.
For a description of this member, see .
Method
2.0.0.0
System.Collections.IList
This member is an explicit interface member implementation. It can be used only when the instance is cast to the interface.
For a description of this member, see .
An object implementing that can be bound to a data source.
Method
2.0.0.0
System.Web.UI.DataSourceView
To be added.
Gets the named data source view associated with the data source control.
Returns the named object associated with the control.
The name of the view to retrieve. If is specified, the default view for the control is retrieved.
Method
2.0.0.0
System.Collections.ICollection
This member is an explicit interface member implementation. It can be used only when the instance is cast to the interface.
For a description of this member, see .
An object implementing containing names representing the list of view objects associated with the object.
Property
System.ComponentModel.DefaultValue("")
System.ComponentModel.Editor("System.ComponentModel.Design.MultilineStringEditor,System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")
System.Web.UI.PersistenceMode(System.Web.UI.PersistenceMode.InnerProperty)
System.String
To be added.
In declarative scenarios, the property is specified as a multiline inner property of the object. An inner property is compatible with XSL style sheet data, because it enables you to format the style sheet in any way and ignore character padding issues such as padding quote characters.
If both the and properties are set, the property takes precedence and the data in the XSL style sheet file (.xsl) is used instead of the style sheet elements specified in the property. If an XPath expression is set using the property, it is applied after the XML data is transformed.
If you change the value of the property, the event is raised. If caching is enabled and you change the value of , the cache is invalidated.
The class uses the deprecated class to perform XSL transformations. If you want to use style sheet features that were introduced after the class was deprecated, apply the transforms manually by using the class.
Gets or sets a block of Extensible Stylesheet Language (XSL) data that defines an XSLT transformation to be performed on the XML data managed by the control.
2.0.0.0
Property
System.ComponentModel.Browsable(false)
System.Xml.Xsl.XsltArgumentList
To be added.
Set the property when the event is raised to ensure the XSLT parameters are available at the time that the XSLT transformation is applied to the XML data.
If the property is set to true and the property is set, the cache entries are not automatically invalidated when the parameters change in the transforms argument list. In that case, you must write code to invalidate the cache by setting the property.
Provides a list of XSLT arguments that are used with the style sheet defined by the or properties to perform a transformation on the XML data.
2.0.0.0
Property
System.ComponentModel.DefaultValue("")
System.ComponentModel.Editor("System.Web.UI.Design.XslTransformFileEditor, System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", "System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")
System.String
To be added.
If both the and properties are set, the property takes precedence and the data in the XSL style sheet file (.xsl) is used instead of the style sheet elements specified in the property. If an XPath expression is set using the property, it is applied after the XML data is transformed.
If you change the value of the property, the event is raised. If caching is enabled and you change the value of , the cache is invalidated.
The class uses the deprecated class to perform XSL transformations. If you want to use style sheet features that were introduced after the class was deprecated, apply the transforms manually by using the class.
Specifies the file name of an Extensible Stylesheet Language (XSL) file (.xsl) that defines an XSLT transformation to be performed on the XML data managed by the control.
2.0.0.0
Event
System.EventHandler
Handle the event to set the property with an object before the control performs an XML transformation.
For more information about handling events, see [<topic://cpconEventsOverview>].
Occurs before the style sheet that is defined by the property or identified by the property is applied to XML data.
2.0.0.0
Property
System.ComponentModel.DefaultValue("")
System.String
To be added.
For more information on XPath data-binding expressions, see Binding a Tabular Control to the XmlDataSource Control.
Specifies an XPath expression to be applied to the XML data contained by the property or by the XML file indicated by the property.
2.0.0.0