Data Grid

Populate GridView with Your Own Database Stored Procedures

Description
This customization shows how to change the appearance of cursor when moving over cells in the DataGrid.
Variables
Applies to
Page class
Code
 
/// 
/// Calls custom stored procedure.
/// 
private System.Data.DataSet CallCustomStoredProcedureForGridView() 
{
	
    	/// Step 1: Configure parameters for your stored procedure if the stored procedure accepts parameters.
    	//BaseClasses.Data.StoredProcedureParameter firstParameter = null;
    	
    	/// For SQL Server: Use parameter type System.Data.SqlDbType
    	//firstParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeID", 5, System.Data.SqlDbType.Int, System.Data.ParameterDirection.Input);
	
	/// For Oracle: Use parameter type System.Data.OracleClient.OracleType
	//firstParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeID", 5, System.Data.OracleClient.OracleType.Int, System.Data.ParameterDirection.Input);
	
	/// For MySql: Use parameter type MySql.Data.MySqlClient.MySqlDbType
	//firstParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeID", 5, MySql.Data.MySqlClient.MySqlDbType.Int, System.Data.ParameterDirection.Input, true);
	
    	//BaseClasses.Data.StoredProcedureParameter secondParameter = null;
    	
    	/// For SQL Server: Use parameter type System.Data.SqlDbType
    	//secondParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeLastName", "Smith", System.Data.SqlDbType.VarChar, System.Data.ParameterDirection.Input);

	/// For Oracle: Use parameter type System.Data.OracleClient.OracleType
    	//secondParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeLastName", "Smith", System.Data.OracleClient.OracleType.VarChar, System.Data.ParameterDirection.Input);
    	
	/// For MySql: Use parameter type MySql.Data.MySqlClient.MySqlDbType
    	//secondParameter = new BaseClasses.Data.StoredProcedureParameter("@pk_EmployeeLastName", "Smith", MySql.Data.MySqlClient.MySqlDbType.VarChar, System.Data.ParameterDirection.Input, true);
	  
  /// Note, in case you need to return output value from the Stored procedure you might use the following code:
  /// BaseClasses.Data.StoredProcedureParameter thirdParameter = null;
  /// string myvar = "";
  /// thirdParameter = New BaseClasses.Data.StoredProcedureParameter("@paramName", myvar, System.Data.SqlDbType.VarChar, System.Data.ParameterDirection.Output)
  /// NOTE: if this parameter has a string type such as varchar, nvarchar, string, etc. you have to set its size:
  /// thirdParameter.Size = 10
	
	
	/// Step 2: Add the configured parameters to an array list.
  //BaseClasses.Data.StoredProcedureParameter[] parameterList = new BaseClasses.Data.StoredProcedureParameter[] { firstParameter, secondParameter, thirdParameter };
	
	/// Skip steps 1 and 2 if stored procedure does not accept parameters.
	
	BaseClasses.Data.StoredProcedure myStoredProcedure = null;
	myStoredProcedure = new BaseClasses.Data.StoredProcedure("DatabaseNorthwind1", "Stored_Procedure_Name", null);

	/// Step 3: If the stored procedure accepts parameters, use the following
	/// myStoredProcedure = New BaseClasses.Data.StoredProcedure("DatabaseNorthwind1", "Stored_Procedure_Name", parameterList);   



	/// Step 4: Run the stored procedure.    
	/// RunQuery() will return true if stored procedure successfully executed. Otherwise, it will return false.
	/// Use RunQuery or RunNonQuery.  RunQuery is used when a set of records is being returned.  RunNonQuery is used when one or more values are returned through output parameters.
	
	if (myStoredProcedure.RunQuery()) 
	{
      /// If you have output parameter, use code like:
      /// System.Data.IDataParameter outputParameter; 
      /// outputParameter = (System.Data.IDataParameter)(myStoredProcedure.OutputParameters(0));
      /// string myText = outputParameter.Value.ToString();
      
	    /// Result from stored procedure is available 
	    /// as a DataSet or as an array of RecordValue objects.      
	    return myStoredProcedure.DataSet;
	}
	else 
	{
	    ///You can raise an exception in the custom stored procedure and catch the exception and reporting it to the user.
	    ///To raise the exception:
	
	    ///SET NOCOUNT ON;
	    ///RAISERROR (N'My custom error message goes here', 11, 1)
	
	    ///IMPORTANT: If you raise an error that has a severity level of 10 or less, it is considered  
	    ///a warning, and no exception is raised. The severity of the error must be between 11 and 20
	    ///for an exception to be thrown.
	
	    ///Once the exception is raised, you can look at:
	    ///myStoredProcedure.ErrorMessage to get the text of the error message and use RegisterJScriptAlert to report this to the user.

	    return null;
	}
}

 
Applies to
Page class
Code
 
	public void LoadData() 
	{
		//  Load the GridView control when page loads.
		this.LoadGridControl();
	}

     
Applies to
Page class
Code
 
/// 
/// Binds the GridView control with data from stored procedure.
/// 
private void LoadGridControl() 
{
	//  Enable pagination for the GridView control.
	this.MyGrid.AllowPaging = true;
	this.MyGrid.DataSource = this.CallCustomStoredProcedureForGridView();
	//  Save the data obtained from stored procedure in
	//  session to be used re-bind the GridView control
	//  after postback occurs since GridView control loses 
	//  data after postback occurs.
	this.Page.Session["DataSet"] = this.MyGrid.DataSource;
	//  Let the GridView control handle rendering of columns
	//  and their names.
	this.MyGrid.AutoGenerateColumns = true;
	this.MyGrid.DataBind();
	this.MyGrid.Visible = true;
}

     
Applies to
Page class
Code
 
/// 
/// Handles pagination for the GridView control.
/// 
protected void gridView_PageIndexChanging(object sender, GridViewPageEventArgs e) 
{
	//  Set the GridView control to display
	//  new page
	this.MyGrid.PageIndex = e.NewPageIndex;
	//  Obtain the stored procedure data
	//  that was saved in session.
	object ds = this.Page.Session["DataSet"];
	if (ds != null) 
	{
	    //  Re-bind the GridView control with the data
	    //  from session.
	    this.MyGrid.DataSource = (DataSet)ds;
	    this.MyGrid.DataBind();
	    this.MyGrid.Visible = true;
	}
	else 
	{
	    this.MyGrid.Visible = false;
	}
}
    
     

Terms of Service Privacy Statement