Saturday, February 28, 2009

Add columns in GridView dynamically

Create a class with GridViewTemplate Name, copy and paste the the code in between // GridViewTemplate class - starts and // GridViewTemplate class - ends in GridViewTemplate class

// GridViewTemplate class - starts
public class GridViewTemplate : ITemplate
{
private DataControlRowType templateType;
private string columnName;
private string dataType;

public GridViewTemplate(DataControlRowType type, string colname, string DataType)
{
templateType = type;
columnName = colname;
dataType = DataType;
}

public void InstantiateIn(System.Web.UI.Control container)
{
switch (templateType)
{
case DataControlRowType.Header:
Literal lc = new Literal();
lc.Text = "" + columnName + "";
container.Controls.Add(lc);
break;
case DataControlRowType.DataRow:
if (!columnName.Equals("Name"))
{
Button bl = new Button();
bl.DataBinding += new EventHandler(this.bl_DataBinding);
container.Controls.Add(bl);
}
else
{
Label l = new Label();
l.DataBinding += new EventHandler(this.l_DataBinding);
container.Controls.Add(l);
}

break;
default:
break;
}
}


private void bl_DataBinding(Object sender, EventArgs e)
{
Button bl = (Button)sender;
GridViewRow row = (GridViewRow)bl.NamingContainer;
bl.Text = DataBinder.Eval(row.DataItem, columnName).ToString();
}

private void l_DataBinding(Object sender, EventArgs e)
{
Label l = (Label)sender;
// get the containing row
GridViewRow row = (GridViewRow)l.NamingContainer;
// get the raw data value and make it pretty
l.Text = DataBinder.Eval(row.DataItem, columnName).ToString();
}
}

// GridViewTemplate class - ends

Now Add a GridView control in the aspx with grdMain name, put the below code on page load of aspx page

grdMain.Columns.Clear();
DataTable dtReport = new DataTable();
DataColumn col = new DataColumn("test1");
DataColumn col1 = new DataColumn("test2");
DataColumn col2 = new DataColumn("test3");

dtReport.Columns.Add(col);
dtReport.Columns.Add(col1);
dtReport.Columns.Add(col2);

DataRow dr1 = dtReport.NewRow();
dr1["test1"] = "One";
dr1["test2"] = "One1";
dr1["test3"] = "One2";

dtReport.Rows.Add(dr1);


for (int i = 0; i < dtReport.Columns.Count; i++)
{
TemplateField tf = new TemplateField();
tf.ItemTemplate =
new GridViewTemplate(DataControlRowType.DataRow,
dtReport.Columns[i].ColumnName,
dtReport.Columns[i].DataType.Name);
tf.HeaderTemplate =
new GridViewTemplate(DataControlRowType.Header,
dtReport.Columns[i].ColumnName,
dtReport.Columns[i].DataType.Name);
grdMain.Columns.Add(tf);
}

// bind and display the data
grdMain.DataSource = dtReport;
grdMain.DataBind();
grdMain.Visible = true;

Compile and run the application.

Happy Coding

Thursday, February 19, 2009

String Comparisions : Performance test to find out blank strings

We can compare blank strings as below.

str == ""
str == string.Empty
str.Equals("")
st.Equals(string.Empty)
str.Length==0

I did small performance testing to find out which gives us best performance and I found


3. str == "" and str == string.Empty almost same
2. str.Equals("") and st.Equals(string.Empty) almost same
1. str.Length==0 real difference (It takes the least time)

You can also test it using the below code:

string print = "";
string str = "test";
long startTicks = DateTime.Now.Ticks;

for (int i = 0; i < 40000000; i++)
{
if (str == "")
{
}

}
long endTicks = DateTime.Now.Ticks - startTicks;
print = "str == \"\" " + endTicks.ToString() + "\n";
startTicks = DateTime.Now.Ticks;
for (int i = 0; i < 40000000; i++)
{
if (str.Equals(""))
{
}

}
endTicks = DateTime.Now.Ticks - startTicks;
print += "str.Equals(\"\") " + endTicks.ToString() + "\n";
startTicks = DateTime.Now.Ticks;
for (int i = 0; i < 40000000; i++)
{
if (str == string.Empty)
{
}

}
endTicks = DateTime.Now.Ticks - startTicks;
print += "str == string.Empty " + endTicks.ToString() + "\n";
startTicks = DateTime.Now.Ticks;
for (int i = 0; i < 40000000; i++)
{
if (str.Equals(string.Empty))
{
}

}
endTicks = DateTime.Now.Ticks - startTicks;
print += "str.Equals(string.Empty) " + endTicks.ToString() + "\n";
startTicks = DateTime.Now.Ticks;
for (int i = 0; i < 40000000; i++)
{
if (str.Length==0)
{
}
}
endTicks = DateTime.Now.Ticks - startTicks;
print += "str.Length==0 " + endTicks.ToString() + "\n";
MessageBox.Show(print);

Happy Coding

Site Meter