Webpart-GridView Paging Problem
Hi, Please excuse me as this is not a pure sharepoint or Asp.NET Application, So I have posted in Sharepoint Overflow as well as Stack Overflow. thank you.
I have developed a Webpart and deployed in SP 2007 Site. I am displaying the data in a gridview and I have enabled the paging and it can show 10 records. But when I click on the next Page number, then it comes up error " An unexpected error has occurred. Troubleshoot issues with Windows SharePoint Services " Could any one tell me what is missed here.
using System;
using System.Runtime.InteropServices;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Serialization;
using System.Data;
using System.Data.SqlClient;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls;
using Microsoft.SharePoint.WebPartPages;
namespace EVentHandlerWebPartGridView
{
[Guid("d75310a6-2db3-431c-a45d-351e4ba0bda1")]
public class EventHandlerWebPartGridView : System.Web.UI.WebControls.WebParts.WebPart
{
// Constructors for the web Part
public EventHandlerWebPartGridView()
{
}
// Member variable for the class
private string _cnString = string.Empty;
// control definitions
protected Label lblError;
protected Button btnExecuteSQL;
protected TextBox txtSql;
protected GridView gvResults;
// WebPart Parameter for getting the Connection string
[
WebBrowsable(true),
WebDisplayName("Connection String"),
Personalizable(PersonalizationScope.User)
]
public string CNString
{
get { return _cnString; }
set { _cnString = value; }
}
// Override Method- place to initialize the controls
protected override void CreateChildControls()
{
//label initialization and Properties
lblError = new Label();
this.Controls.Add(lblError);
// textbox control and Propetrties
txtSql = new TextBox();
txtSql.Width = Unit.Pixel(400);
txtSql.Height = Unit.Pixel(200);
txtSql.TextMode = TextBoxMode.MultiLine;
this.Controls.Add(txtSql);
//button Initialization and Properties
btnExecuteSQL = new Button();
btnExecuteSQL.Text = "Execute SQL";
btnExecuteSQL.ToolTip = "Click On this to see the Reults of the SQL Query";
btnExecuteSQL.Click += new EventHandler(btnExecuteSQL_Click);
this.Controls.Add(btnExecuteSQL);
//gridview Initialization
gvResults = new GridView();
gvResults.Width = Unit.Percentage(100);
gvResults.AlternatingRowStyle.BackColor = System.Drawing.Color.Blue;
gvResults.AllowPaging = true;
gvResults.PageSize = 10;
Controls.Add(gvResults);
}
//Button Click Event handler
protected void btnExecuteSQL_Click(object sender, EventArgs e)
{
// if the connection string is not empty
if (_cnString.Trim() != string.Empty)
{
try
{
SqlConnection con = new SqlConnection(_cnString);
SqlCommand cmd = new SqlCommand(txtSql.Text, con);
SqlDataAdapter da = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
da.Fill(ds);
gvResults.DataSource = ds.Tables[0].DefaultView;
gvResults.DataBind();
}
// Any Errors in the above Code
catch (Exception ex)
{
gvResults.DataSource = null;
gvResults.DataBind();
lblError.Text = ex.Message;
lblError.Visible = true;
}
}
// If the Connection string is Empty
else
{
gvResults.DataSource = null;
gvResults.DataBind();
lblError.Text = "Please Enter a Connection string";
lblError.Visible = true;
}
}
// Rendering the Data nows
protected override void Render(HtmlTextWriter writer)
{
writer.RenderBeginTag(HtmlTextWriterTag.Table); //table Starts
writer.RenderBeginTag(HtmlTextWriterTag.Tr); // Tr Starts
wri开发者_如何转开发ter.AddAttribute(HtmlTextWriterAttribute.Colspan, "2");// Adds an attribute tag
writer.RenderBeginTag(HtmlTextWriterTag.Td); // Td tag starts Here
lblError.RenderControl(writer);
writer.RenderEndTag();
writer.RenderEndTag(); //tr nd
writer.AddAttribute(HtmlTextWriterAttribute.Valign, "top");
writer.RenderBeginTag(HtmlTextWriterTag.Tr); // tr
writer.RenderBeginTag(HtmlTextWriterTag.Td); //td
writer.Write("Enter a SQL Statement");
writer.RenderEndTag();// end td
// Now Display the Text Box
writer.RenderBeginTag(HtmlTextWriterTag.Td); // Td start Tag
txtSql.RenderControl(writer);
writer.RenderEndTag(); // td End Tag
writer.RenderEndTag();//tr End
// Now Display the Button
writer.RenderBeginTag(HtmlTextWriterTag.Tr);
writer.RenderBeginTag(HtmlTextWriterTag.Td);
btnExecuteSQL.RenderControl(writer);
writer.RenderEndTag();
writer.RenderEndTag();
//Now Display the GridView
writer.RenderBeginTag(HtmlTextWriterTag.Tr);
writer.RenderBeginTag(HtmlTextWriterTag.Td);
gvResults.RenderControl(writer);
writer.RenderEndTag();
writer.RenderEndTag();
writer.RenderEndTag(); //Table End
}
}
}
In the web.config file change CustomErrors="On" to CustomErrors="Off". That will show the actual error message. You are probably not handling the paging events.
精彩评论