Monday, 13 August 2012

ASP.NET Simple SearchBox

Introduction:
    Going to explain Simple Search Box using SqlDataSource And LIKE Query..

Explaination:
We Have TextBox1 and Button1 And GridView1

HTML Markup:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Search-Mahad-aspspirits.aspx.cs" Inherits="Search_Mahad_aspspirits" %>

<!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>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    
        Search
        <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
        <asp:Button ID="Button1" runat="server" onclick="Button1_Click" 
            Text="Search!" />
    
        <br />
        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
            BackColor="White" BorderColor="#E7E7FF" BorderStyle="None" BorderWidth="1px" 
            CellPadding="3" DataSourceID="SqlDataSource1" GridLines="Horizontal">
            <FooterStyle BackColor="#B5C7DE" ForeColor="#4A3C8C" />
            <RowStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" />
            <Columns>
                <asp:BoundField DataField="CampusCode" HeaderText="CampusCode" 
                    SortExpression="CampusCode" />
                <asp:BoundField DataField="StudentName" HeaderText="StudentName" 
                    SortExpression="StudentName" />
                <asp:BoundField DataField="Gender" HeaderText="Gender" 
                    SortExpression="Gender" />
                <asp:BoundField DataField="Age" HeaderText="Age" SortExpression="Age" />
            </Columns>
            <PagerStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" HorizontalAlign="Right" />
            <SelectedRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="#F7F7F7" />
            <HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#F7F7F7" />
            <AlternatingRowStyle BackColor="#F7F7F7" />
        </asp:GridView>
    
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
            ConnectionString="<%$ ConnectionStrings:gomahadConnectionString %>" 
            SelectCommand="SELECT CampusCode, StudentName, Gender, Age FROM registration WHERE StudentName LIKE '%' + @StName + '%'">
            <SelectParameters>
                <asp:ControlParameter ControlID="TextBox1" Name="StName" PropertyName="Text" />
            </SelectParameters>
        </asp:SqlDataSource>
    
    </div>
    </form>
</body>
</html>

First of all Place a GridView on your Desired place, then click on GridView Top Right small arrow and Select DataSource, Choose New DataSource.. Then After Setup your SqlDataSource On "Configure SELECT Statement"


As you can See you have "Parameter Source" By which you can also Get Value From "Control, QueryString, Session, Form, Cookie"

on Button Click you can write Code of DataBind.

protected void Button1_Click(object sender, EventArgs e)
    {
        SqlDataSource1.DataBind();
        GridView1.DataBind();
    }
You can see with a single line of C# Code we Can Achieve this Goal by SqlDataSource.
Hope this will help you!
Good Luck`

Saturday, 11 August 2012

ASP.NET : ViewState Viewer!

I'm Dedicating this ViewState Viewer to ASP.NET Students of AUC..
It will decode ViewState Rendered Form in to human readable form..
For Testing write code
ViewState["Hello"] = "YourMessage Here";
Right click on your WebApplication.aspx Go to View the Source..
and copy the value of the ViewState Past In the application and Press "Decode".
    
*****TESTING******
For Testing Past:
/wEPDwUKMTg1ODczOTU0Ng8WBB4JU29tZVRoaW5nBQxoZWxsbywgTWFoYWQeA0FVQwURU2lyLiBBdGlmIEh1c3NhaW5kZL+umfdCAFV60ZIc/BU4cb2KfcQK

It will give out put : 1858739546 SomeThing hello, Mahad AUC Sir. Atif Hussaindd????B

the Code was:
ViewState["SomeThing"] = "hello, Mahad";
ViewState["AUC"] = "Sir. Atif Hussain";
   

Note: Its For Learning Purposes, So Please no -ve comments.
Download Link : 

Wednesday, 8 August 2012

How To find last updated date in datatable values in c#.net

I've Answered : http://forums.asp.net/t/1830090.aspx/1?how+to+find+last+updated+date+in+datatable+values+in+c+net

Question :

Hi friends,
    I have requirement like i need to find last updated date from DataView . I have data like Project ID,UpdatedDate If same ProjectID i have 4 records,with different updated dates.So i need to find last updated value and compare other date. How can i get this last updated table using Dataview or data table.Can you share is there any simple method to do this..
Answer:
Its Example
I have Column "ReceiptDate"
ReceiptDate
4/21/2012
4/21/2012
4/21/2012
NULL
4/21/2012
4/21/2012
NULL
4/21/2012
NULL
4/21/2012
NULL
5/23/2012
4/23/2012
NULL
5/2/2012
5/27/2012
NULL
5/27/2012
6/9/2012
NULL
6/9/2012
NULL
6/9/2012
So, I know 6/9/2012 Is Highest Date So, I can use This Query
SELECT MAX(ReceiptDate) FROM MyTable
Result : 6/9/2012
SqlConnection Conn = new SqlConnection(@"Data Source=(local);Initial Catalog=YOUR_DATABASE;Integrated Security=True");
        SqlCommand Comm1 = new SqlCommand("SELECT MAX(ReceiptDate) FROM YourTable", Conn);
        Conn.Open();
        SqlDataReader DR1 = Comm1.ExecuteReader();
        if (DR1.Read())
        {
            int Val = Convert.ToInt32(DR1.GetValue(0).ToString());
            ResultLabel.Text = Convert.ToString(Val);
        }
        Conn.Close();
Dont Foget to Import namespace
using System.Data.SqlClient;
Good Luck`



ASP.NET GridView Fix Header!


GridView Markup
Below is the GridView Markup
<div id = "container" style ="height:200px;overflow:auto;width:617px ">
<asp:GridView ID="GridView1" runat="server"
    AutoGenerateColumns = "false" CssClass = "grid">
   <Columns>
    <asp:BoundField ItemStyle-Width = "200px"
    DataField = "CustomerID" HeaderText = "CustomerId" />
    <asp:BoundField ItemStyle-Width = "200px"
    DataField = "City" HeaderText = "City"/>
    <asp:BoundField ItemStyle-Width = "200px"
    DataField = "Country" HeaderText = "Country"/>
   </Columns>
</asp:GridView>
</div>

You will notice above I have placed the GridView inside a DIV of fixed height and width and setting its overflow property to auto so that the scrollbars are available. Also I have set the width of the Div slightly more than the GridView so that the horizontal scrollbar is hidden and it can accommodate the vertical scrollbar.
 
Binding the GridView
Below are the methods to Bind the GridView control with data
C#
private void BindGrid()
{
    DataTable dt = new DataTable();
    String strConnString = System.Configuration.ConfigurationManager
                .ConnectionStrings["conString"].ConnectionString;
    SqlConnection con = new SqlConnection(strConnString);
    SqlDataAdapter sda = new SqlDataAdapter();
    SqlCommand cmd = new SqlCommand("select * from customers");
    cmd.Connection = con;
    sda.SelectCommand = cmd;
    sda.Fill(dt);
    GridView1.DataSource = dt;
    GridView1.DataBind();
    GridView1.HeaderRow.Attributes["style"] = "display:none";
    GridView1.UseAccessibleHeader = true;
    GridView1.HeaderRow.TableSection = TableRowSection.TableHeader;
}

VB.Net
Private Sub BindGrid()
 Dim dt As New DataTable()
 Dim strConnString As [String] = System.Configuration.ConfigurationManager _
                    .ConnectionStrings("conString").ConnectionString
 Dim con As New SqlConnection(strConnString)
 Dim sda As New SqlDataAdapter()
 Dim cmd As New SqlCommand("select * from customers")
 cmd.Connection = con
 sda.SelectCommand = cmd
 sda.Fill(dt)
 GridView1.DataSource = dt
 GridView1.DataBind()
 GridView1.HeaderRow.Attributes("style") = "display:none"
 GridView1.UseAccessibleHeader = True
 GridView1.HeaderRow.TableSection = TableRowSection.TableHeader
End Sub

Above after binding the GridView I am hiding the GridView header row by setting its display to none. If you set ShowHeader to false it will break the working of sorting library. In the next statements I am modifying the GridView settings so that it renders with THEAD and TBODY tags which are necessary for the library in order to sort a table
 
Building the Dummy Header
For preparing the dummy header we will need to extract the header row of the GridView as shown in the screenshot
ScrollableGridViewwith sorting.png
Now complete paste it above the GridView and remove display:none so that the dummy header is visible, I have also provided ID to the dummy header table and your dummyHeader and the scrollable GridView is ready
ScrollableGridViewwith sorting2.png
CSS
Add the following CSS to the head section of the page
<style type = "text/css">
    .sortAsc
    {
        background-imageurl(images/asc.gif);
        background-repeatno-repeat;
        background-positioncenter right;
        cursorpointer;
        width:200px;
    }
    .sortDesc
    {
        background-imageurl(images/desc.gif);
        background-repeatno-repeat;
        background-positioncenter right;
        cursorpointer;
        width:200px;
    }
    .grid
    {
        font-family:Arial;
        font-size:10pt;
        width:600px
    }
    .grid THEAD
    {
         background-color:Green;
         color:White;
    }
</style>
 
Client Side Sorting
Now for the Client Side Script I have used the tablesorter jQuery Plugin which will be used to sort the GridView control. Hence add the following scripts to your page
<script src="scripts/jquery-1.3.2.min.js" type="text/javascript"></script>
<script src="scripts/jquery.tablesorter.min.js" type="text/javascript"></script>
<script type = "text/javascript">
    $(document).ready(function() {
    $("#<%=GridView1.ClientID%>").tablesorter();
        SetDefaultSortOrder();
    });
 
    function Sort(cell, sortOrder) {
        var sorting = [[cell.cellIndex, sortOrder]];
        $("#<%=GridView1.ClientID%>").trigger("sorton", [sorting]);
        if (sortOrder == 0) {
            sortOrder = 1;
            cell.className = "sortDesc";
        }
        else {
            sortOrder = 0;
            cell.className = "sortAsc";
        }
        cell.setAttribute("onclick""Sort(this, " + sortOrder + ")");
        cell.onclick = function() { Sort(this, sortOrder); };
        document.getElementById("container").scrollTop = 0;
    }
 
    function SetDefaultSortOrder() {
        var gvHeader = document.getElementById("dummyHeader");
        var headers = gvHeader.getElementsByTagName("TH");
        for (var i = 0; i < headers.length; i++) {
            headers[i].setAttribute("onclick""Sort(this, 1)");
            headers[i].onclick = function() { Sort(this, 1); };
            headers[i].className = "sortDesc";
        }
    }
</script>

All the client side methods are explained below
The following method notifies the tablesorter library the ID of the control that needs to be sorted and also calls theSetDefaultSortOrder method to set the default sort order.
    $(document).ready(function() {
    $("#<%=GridView1.ClientID%>").tablesorter();
        SetDefaultSortOrder();
    });
 
The following function as the name suggests sets the default sort order for the GridView in the dummy header that we’ve created earlier
function SetDefaultSortOrder() {
        var gvHeader = document.getElementById("dummyHeader");
        var headers = gvHeader.getElementsByTagName("TH");
        for (var i = 0; i < headers.length; i++) {
            headers[i].setAttribute("onclick""Sort(this, 1)");
            headers[i].onclick = function() { Sort(this, 1); };
            headers[i].className = "sortDesc";
        }
}
 
This function get’s called when user clicks on the header row for sorting it accepts the cell and the sort order in which the grid needs to be sorted.
function Sort(cell, sortOrder) {
        var sorting = [[cell.cellIndex, sortOrder]];
        $("#<%=GridView1.ClientID%>").trigger("sorton", [sorting]);
        if (sortOrder == 0) {
            sortOrder = 1;
            cell.className = "sortDesc";
        }
        else {
            sortOrder = 0;
            cell.className = "sortAsc";
        }
        cell.setAttribute("onclick""Sort(this, " + sortOrder + ")");
        cell.onclick = function() { Sort(this, sortOrder); };
        document.getElementById("container").scrollTop = 0;
}
 
Checkout the demo GridView below

CustomerIdCityCountry
ALFKIBerlinGermany
ANATRMéxico D.F.Mexico
ANTONMéxico D.F.Mexico
AROUTLondonUK
BERGSLuleåSweden
BLAUSMannheimGermany
BLONPStrasbourgFrance
BOLIDMadridSpain
BONAPMarseilleFrance
BOTTMTsawassenCanada
BSBEVLondonUK
CACTUBuenos AiresArgentina
CENTCMéxico D.F.Mexico
CHOPSBernSwitzerland
COMMISao PauloBrazil
CONSHLondonUK
DRACDAachenGermany
DUMONNantesFrance
EASTCLondonUK
ERNSHGrazAustria
FAMIASao PauloBrazil
FISSAMadridSpain
FOLIGLilleFrance
FOLKOBräckeSweden
FRANKMünchenGermany
FRANRNantesFrance
FRANSTorinoItaly
FURIBLisboaPortugal
GALEDBarcelonaSpain
GODOSSevillaSpain
GOURLCampinasBrazil
GREALEugeneUSA
GROSRCaracasVenezuela
HANARRio de JaneiroBrazil
HILAASan CristóbalVenezuela
HUNGCElginUSA
HUNGOCorkIreland
ISLATCowesUK
KOENEBrandenburgGermany
LACORVersaillesFrance
LAMAIToulouseFrance
LAUGBVancouverCanada
LAZYKWalla WallaUSA
LEHMSFrankfurt a.M.Germany
LETSSSan FranciscoUSA
LILASBarquisimetoVenezuela
LINODI. de MargaritaVenezuela
LONEPPortlandUSA
MAGAABergamoItaly
MAISDBruxellesBelgium
MEREPMontréalCanada
MORGKLeipzigGermany
NORTSLondonUK
OCEANBuenos AiresArgentina
OLDWOAnchorageUSA
OTTIKKölnGermany
PARISParisFrance
PERICMéxico D.F.Mexico
PICCOSalzburgAustria
PRINILisboaPortugal
QUEDERio de JaneiroBrazil
QUEENSao PauloBrazil
QUICKCunewaldeGermany
RANCHBuenos AiresArgentina
RATTCAlbuquerqueUSA
REGGCReggio EmiliaItaly
RICARRio de JaneiroBrazil
RICSUGenèveSwitzerland
ROMEYMadridSpain
SANTGStavernNorway
SAVEABoiseUSA
SEVESLondonUK
SIMOBKobenhavnDenmark
SPECDParisFrance
SPLIRLanderUSA
SUPRDCharleroiBelgium
THEBIPortlandUSA
THECRButteUSA
TOMSPMünsterGermany
TORTUMéxico D.F.Mexico
TRADHSao PauloBrazil
TRAIHKirklandUSA
VAFFEÅrhusDenmark
VICTELyonFrance
VINETReimsFrance
WANDKStuttgartGermany
WARTHOuluFinland
WELLIResendeBrazil
WHITCSeattleUSA
WILMKHelsinkiFinland
WOLZAWarszawaPoland

The above code has been tested in the following browsers

Internet Explorer  FireFox  Chrome  Safari  Opera 

Author: 

Good Luck`..

Twitter Delicious Facebook Digg Stumbleupon Favorites More