Parameter Class
Provides a mechanism that data source controls use to bind to application variables, user identities and choices, and other data. Serves as the base class for all ASP.NET parameter types.
System.Web.UI.WebControls.Parameter
System.Web.DynamicData.DynamicControlParameter
System.Web.DynamicData.DynamicQueryStringParameter
System.Web.UI.WebControls.ControlParameter
System.Web.UI.WebControls.CookieParameter
System.Web.UI.WebControls.FormParameter
System.Web.UI.WebControls.ProfileParameter
System.Web.UI.WebControls.QueryStringParameter
System.Web.UI.WebControls.RouteParameter
System.Web.UI.WebControls.SessionParameter
Assembly: System.Web (in System.Web.dll)
The Parameter type exposes the following members.
Name | Description | |
---|---|---|
![]() | Parameter | Initializes a new default instance of the Parameter class. |
![]() | Parameter(Parameter) | Initializes a new instance of the Parameter class with the values of the original, specified instance. |
![]() | Parameter(String) | Initializes a new instance of the Parameter class, using the specified name. |
![]() | Parameter(String, DbType) | Initializes a new instance of the Parameter class, using the specified name and database type. |
![]() | Parameter(String, TypeCode) | Initializes a new instance of the Parameter class, using the specified name and type. |
![]() | Parameter(String, DbType, String) | Initializes a new instance of the Parameter class, using the specified name, the specified database type, and the specified value for its DefaultValue property. |
![]() | Parameter(String, TypeCode, String) | Initializes a new instance of the Parameter class, using the specified name, the specified type, and the specified string for its DefaultValue property. |
Name | Description | |
---|---|---|
![]() | ConvertEmptyStringToNull | Gets or sets a value indicating whether the value that the Parameter object is bound to should be converted to Nothing if it is String.Empty. |
![]() | DbType | Gets or sets the database type of the parameter. |
![]() | DefaultValue | Specifies a default value for the parameter, should the value that the parameter is bound to be uninitialized when the Evaluate method is called. |
![]() | Direction | Indicates whether the Parameter object is used to bind a value to a control, or the control can be used to change the value. |
![]() | IsTrackingViewState | Gets a value indicating whether the Parameter object is saving changes to its view state. |
![]() | Name | Gets or sets the name of the parameter. |
![]() | Size | Gets or sets the size of the parameter. |
![]() | Type | Gets or sets the type of the parameter. |
![]() | ViewState | Gets a dictionary of state information that allows you to save and restore the view state of a Parameter object across multiple requests for the same page. |
Name | Description | |
---|---|---|
![]() | Clone | Returns a duplicate of the current Parameter instance. |
![]() ![]() | ConvertDbTypeToTypeCode | Converts a DbType value to an equivalent TypeCode value. |
![]() ![]() | ConvertTypeCodeToDbType | Converts a TypeCode value to an equivalent DbType value. |
![]() | Equals(Object) | Determines whether the specified Object is equal to the current Object. (Inherited from Object.) |
![]() | Evaluate | Updates and returns the value of the Parameter object. |
![]() | Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.) |
![]() | GetDatabaseType | Gets the DbType value that is equivalent to the CLR type of the current Parameter instance. |
![]() | GetHashCode | Serves as a hash function for a particular type. (Inherited from Object.) |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() | LoadViewState | Restores the data source view's previously saved view state. |
![]() | MemberwiseClone | Creates a shallow copy of the current Object. (Inherited from Object.) |
![]() | OnParameterChanged | Calls the OnParametersChanged method of the ParameterCollection collection that contains the Parameter object. |
![]() | SaveViewState | Saves the changes to the Parameter object's view state since the time the page was posted back to the server. |
![]() | SetDirty | Marks the Parameter object so its state will be recorded in view state. |
![]() | ToString | Converts the value of this instance to its equivalent string representation. (Overrides Object.ToString.) |
![]() | TrackViewState | Causes the Parameter object to track changes to its view state so they can be stored in the control's ViewState object and persisted across requests for the same page. |
Name | Description | |
---|---|---|
![]() ![]() | ICloneable.Clone | Returns a duplicate of the current Parameter instance. |
![]() ![]() | IStateManager.IsTrackingViewState | Infrastructure. Gets a value indicating whether the Parameter object is saving changes to its view state. |
![]() ![]() | IStateManager.LoadViewState | Infrastructure. Restores the data source view's previously saved view state. |
![]() ![]() | IStateManager.SaveViewState | Infrastructure. Saves the changes to the Parameter object's view state since the time the page was posted back to the server. |
![]() ![]() | IStateManager.TrackViewState | Infrastructure. Causes the Parameter object to track changes to its view state so they can be stored in the control's ViewState object and persisted across requests for the same page. |
The Parameter class represents a parameter in a parameterized SQL query, a filtering expression, or a business object method call that an ASP.NET data source control uses to select, filter, or modify data. Parameter objects are contained in a ParameterCollection object. Parameter objects are evaluated at run time, to bind the values of the variables they represent to whatever method is used by a data source control to interact with data.
Use classes that derive from Parameter with data source and data-bound controls to build Web-based data applications. These parameter classes are used by data source controls to bind specific kinds of values found in Web applications to placeholders in SQL query strings, business object method parameters, and more. The following table lists parameter types that are included in ASP.NET.
Binds any public property of a Web server control. | |
Binds a form field. | |
Binds a session-state field. | |
Binds a route URL parameter. | |
Binds a cookie field. | |
Binds a query-string parameter. | |
Binds a profile field. |
Extend the base Parameter class when you want to implement your own custom parameter types.
Parameter objects are very simple: they have a Name and a Type property, can be represented declaratively, and can track state across multiple HTTP requests. All parameters support a DefaultValue property, for cases when a parameter is bound to a value, but the value evaluates to Nothing at run time.
When using a collection of Parameter objects with a data source control, their order in the collection might matter. For more information on how parameters are used, see Using Parameters with the SqlDataSource Control and Using Parameters with the ObjectDataSource Control.
The following example shows how to use the selected value of a DropDownList control in the Where clause of a SQL query. The example uses the ControlParameter class, which derives from the ControlParameter class.
The SelectCommand element defines the query with a parameter named "@Title" where the value from DropDownList1 should go. The ControlParameter element specifies that the "@Title" placeholder will be replaced by the value of the SelectedValue property of the DropDownList1 control. The ControlParameter element is added to the SelectParameters collection of the SqlDataSource control.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>ASP.NET Example</title> </head> <body> <form id="form1" runat="server"> <p><asp:dropdownlist id="DropDownList1" runat="server" autopostback="True"> <asp:listitem selected="True">Sales Representative</asp:listitem> <asp:listitem>Sales Manager</asp:listitem> <asp:listitem>Vice President, Sales</asp:listitem> </asp:dropdownlist></p> <asp:sqldatasource id="SqlDataSource1" runat="server" connectionstring="<%$ ConnectionStrings:MyNorthwind%>" selectcommand="SELECT LastName FROM Employees WHERE Title = @Title"> <selectparameters> <asp:controlparameter name="Title" controlid="DropDownList1" propertyname="SelectedValue"/> </selectparameters> </asp:sqldatasource> <p><asp:listbox id="ListBox1" runat="server" datasourceid="SqlDataSource1" datatextfield="LastName"> </asp:listbox></p> </form> </body> </html>
The following example is like the previous one, but uses code instead of markup. When the page loads the first time, the DropDownList control has no selected value, and the DefaultValue property of the Parameter object is used.
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="param1avb.aspx.vb" Inherits="param1avb_aspx" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>ASP.NET Example</title> </head> <body> <form id="form1" runat="server"> <div> <asp:DropDownList runat="server" AutoPostBack="True" id="DropDownList1"> <asp:ListItem Value="USA">USA</asp:ListItem> <asp:ListItem Value="UK">UK</asp:ListItem> </asp:DropDownList> <asp:DataGrid runat="server" id="DataGrid1" /> </div> </form> </body> </html>
The following code shows the code-behind class for the page in the previous example.
Partial Class param1avb_aspx Inherits System.Web.UI.Page Private Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Dim sqlSource As SqlDataSource sqlSource = New SqlDataSource(ConfigurationManager.ConnectionStrings("MyNorthwind").ConnectionString, "SELECT FirstName, LastName FROM Employees WHERE Country = @country;") Dim country As New ControlParameter() country.Name = "country" country.Type = TypeCode.String country.ControlID = "DropDownList1" country.PropertyName = "SelectedValue" ' If the DefaultValue is not set, the DataGrid does not ' display anything on the first page load. This is because ' on the first page load, the DropDownList has no ' selected item, and the ControlParameter evaluates to ' String.Empty. country.DefaultValue = "USA" sqlSource.SelectParameters.Add(country) ' Add the SqlDataSource to the page controls collection. Page.Controls.Add(sqlSource) DataGrid1.DataSource = sqlSource DataGrid1.DataBind() End Sub 'Page_Load End Class
The following code example demonstrates how to extend the Parameter class to create a new parameter type that can be used by data source controls and other controls in data-binding scenarios. A data source control can use a StaticParameter parameter to bind to the value of any object, typically a string, declared on a Web Forms page.
Imports System Imports System.ComponentModel Imports System.Security.Permissions Imports System.Web Imports System.Web.UI Imports System.Web.UI.WebControls Namespace Samples.AspNet <AspNetHostingPermission(SecurityAction.Demand, Level:=AspNetHostingPermissionLevel.Minimal)> _ Public Class StaticParameter Inherits Parameter Public Sub New() End Sub ' The StaticParameter(string, object) constructor ' initializes the DataValue property and calls the ' Parameter(string) constructor to initialize the Name property. Public Sub New(name As String, value As Object) MyBase.New(name) DataValue = value End Sub ' The StaticParameter(string, TypeCode, object) constructor ' initializes the DataValue property and calls the ' Parameter(string, TypeCode) constructor to initialize the Name and ' Type properties. Public Sub New(name As String, type As TypeCode, value As Object) MyBase.New(name, type) DataValue = value End Sub ' The StaticParameter copy constructor is provided to ensure that ' the state contained in the DataValue property is copied to new ' instances of the class. Protected Sub New(original As StaticParameter) MyBase.New(original) DataValue = original.DataValue End Sub ' The Clone method is overridden to call the ' StaticParameter copy constructor, so that the data in ' the DataValue property is correctly transferred to the ' new instance of the StaticParameter. Protected Overrides Function Clone() As Parameter Return New StaticParameter(Me) End Function ' The DataValue can be any arbitrary object and is stored in ViewState. Public Property DataValue() As Object Get Return ViewState("Value") End Get Set ViewState("Value") = value End Set End Property ' The Value property is a type safe convenience property ' used when the StaticParameter represents string data. ' It gets the string value of the DataValue property, and ' sets the DataValue property directly. Public Property Value() As String Get Dim o As Object = DataValue If o Is Nothing OrElse Not TypeOf o Is String Then Return String.Empty End If Return CStr(o) End Get Set DataValue = value OnParameterChanged() End Set End Property ' The Evaluate method is overridden to return the ' DataValue property instead of the DefaultValue. Protected Overrides Function Evaluate(context As HttpContext, control As Control) As Object If context Is Nothing Then Return Nothing Else Return DataValue End If End Function End Class ' StaticParameter End Namespace ' Samples.AspNet
Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.