asp.net.ph

Skip Navigation LinksHome > Data Access / ADO.NET > Data Source Controls Overview > Modifying Data Using Data Source Controls

Modifying Data Using Data Source Controls

Web Forms Server Controls   Controls You Can Use on Web Forms   ASP.NET Data Source Controls


Data source controls greatly expand the capabilities of data-bound controls such as the GridView, FormView, and DetailsView controls to modify data at the data source without requiring extensive additional code. The data source control performs the data modification, so data-bound controls can support updates without requiring specific information about the database or other data source. You can use different data source controls with any combination of controls on the page. In addition, you can change the database or data source that a data-bound control works with by changing its DataSourceID to point to a different data source control.

Data Modification Commands

You can configure the SqlDataSource, AccessDataSource, and ObjectDataSource controls with data commands to insert, update, and delete data in their associated data store.

Modifying Data with SQL Commands

The SqlDataSource and AccessDataSource controls enable you to supply SQL commands for modifying data at the data source. The InsertCommand property specifies a SQL command to insert a record into the data source. Similarly, the UpdateCommand property specifies a command used for record updates, and the DeleteCommand property specifies a command used to delete a record from the data source.

The following example shows a SqlDataSource control configured with an UpdateCommand.

NOTE: An SQL statement can and should be written as a single line without any line breaks to avoid errors; the examples shown here are done so only for readability.

<asp:sqldatasource id="messages" runat="server"
   selectcommand="SELECT * FROM aspx_messages"
   updatecommand="UPDATE aspx_messages SET " +
      "MessageFrom=@MessageFrom, " +
      "Email=@Email, " +
      "MessageSubject=@MessageSubject, " +
      "MessageBody=@MessageBody " +
      "WHERE MessageID=@MessageID"
   connectionstring="<%$ ConnectionStrings:aspnet %>" />

 Show me 

For more information, see Modifying Data using the SqlDataSource Control.

Modifying Data with the ObjectDataSource Control

The ObjectDataSource control enables you to specify a data object method for performing a specific type of update. The InsertMethod property specifies the data object method that is called when the ObjectDataSource control inserts an item into the data source. Similarly, the UpdateMethod property specifies the data object method used for item updates, and the DeleteMethod property specifies the method used to delete an item from the data source.

The following code example shows an ObjectDataSource control with its InsertMethod, UpdateMethod, and DeleteMethod properties configured with the names of methods from the underlying data object.

<asp:objectdatasource id="employeeDetailsObject" runat="server" 
   typename="samples.aspnet.controls.northwindemployee" 
   selectmethod="GetEmployee" 
   updatemethod="UpdateEmployee"
   deletemethod="DeleteEmployee"
   insertmethod="InsertEmployee" 
   oninserted="employeeDetailsObject_oninserted" >

   <selectparameters>
      <asp:parameter name="employeeid" />  
   </selectparameters>

   <insertparameters>
      <asp:parameter name="newemployeeid" direction="output" 
         type="int32" defaultvalue="0" />
   </insertparameters>

</asp:objectdatasource>

For more information, see Creating an ObjectDataSource Control Source Object.

Parameters

You can make your data-update scenarios more flexible secure by using parameters to pass values to be inserted, updated, or deleted in a data store. Parameter values can include the values of controls on the page, ASP.NET application variables, session values, and so on.

Parameter values typically come from data-bound controls when those controls invoke an update, insert, or delete operation. Additionally, you can create explicit parameter objects for the data source control for a given operation, which allows you to customize the parameters. For example, you can use an explicit parameter object to specify the type or direction of a parameter, or to define a default value for a parameter in case a null value is passed.

For the ObjectDataSource control, parameter values are passed as arguments when calling the appropriate method of the underlying data object. For the SqlDataSource or AccessDataSource control, parameters are passed to the SQL command used for the update. For more information and examples, see Using Parameters with Data Source Controls.

Events

Data source controls raise events both before and after data is modified. You can use these events to execute code before the data operation occurs, including canceling the operation, and after the data operation has taken place. For example, you can use the Deleting event of the SqlDataSource control to log information about a record about to be deleted. You can also use the Inserted event of the SqlDataSource control to retrieve an auto-generated identity value for the newly inserted record.

See Also

Filtering Data Using Data Source Controls



© 2025 Reynald Nuñez and asp.net.ph. All rights reserved.

If you have any question, comment or suggestion
about this site, please send us a note