For this create a table Users in sql server database with ID,Uname,emlAddress columns
and add some records in it.
and add some records in it.
Add ScriptManager,Ajax UpdatePanel on the page, and inside ContentTemplate place two textbox, two image control to display images and two label controls for related messages.
Set AutoPostBack property of textbox to true.
HTML SOURCE OF PAGE
<asp:ScriptManager ID="ScriptManager1" runat="server"/>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
UserName:
<asp:TextBox ID="txtUName" runat="server"
ontextchanged="txtUName_TextChanged"
AutoPostBack="True"/>
<asp:Image ID="imgUsr" runat="server" Visible="false"/>
<asp:Label ID="lblUsr" runat="server"/>
Email ID:
<asp:TextBox ID="txtId" runat="server"
AutoPostBack="True"
ontextchanged="txtId_TextChanged"/>
<asp:Image ID="imgId" runat="server" Visible="false"/>
<asp:Label ID="lblId" runat="server"></asp:Label>
</ContentTemplate>
</asp:UpdatePanel>
Write below mentioned code in TextChanged Event of textbox
C# CODE
protected
void
txtUName_TextChanged(
object
sender, EventArgs e)
{
if
(txtUName.Text !=
string
.Empty)
{
string
strConnection = ConfigurationManager.ConnectionStrings
[
"ConnectionString"
].ConnectionString;
string
strSelect =
"SELECT COUNT(*) FROM Users WHERE
Uname = @Username"
;
SqlConnection con =
new
SqlConnection(strConnection);
SqlCommand cmd =
new
SqlCommand(strSelect,con);
SqlParameter user =
new
SqlParameter(
"@Username"
, SqlDbType.VarChar);
user.Value = txtUName.Text.Trim().ToString();
cmd.Parameters.Add(user);
con.Open();
int
result = (Int32)cmd.ExecuteScalar();
con.Close();
if
(result >= 1)
{
imgUsr.ImageUrl =
"unavailable.png"
;
imgUsr.Visible =
true
;
lblUsr.Text =
"Username not available"
;
lblUsr.ForeColor = System.Drawing.Color.Red;
}
else
{
imgUsr.ImageUrl =
"tick.png"
;
imgUsr.Visible =
true
;
lblUsr.Text =
"Available"
;
lblUsr.ForeColor = System.Drawing.Color.Green;
}
}
}
Similarly we can check email availability by writing following code
protected
void
txtId_TextChanged(
object
sender, EventArgs e)
{
if
(txtId.Text !=
string
.Empty)
{
string
strConnection = ConfigurationManager.ConnectionStrings
[
"ConnectionString"
].ConnectionString;
string
strSelect =
"SELECT COUNT(*) FROM Users WHERE emlAddress = @Email"
;
SqlConnection con =
new
SqlConnection(strConnection);
SqlCommand cmd =
new
SqlCommand(strSelect, con);
cmd.Parameters.AddWithValue(
"@Email"
, txtId.Text.Trim().ToString());
con.Open();
int
result = (Int32)cmd.ExecuteScalar();
con.Close();
if
(result >= 1)
{
imgId.ImageUrl =
"unavailable.png"
;
imgId.Visible =
true
;
lblId.Text =
"Email already registered"
;
lblId.ForeColor = System.Drawing.Color.Red;
}
else
{
imgId.ImageUrl =
"tick.png"
;
imgId.Visible =
true
;
lblId.Text =
"Available"
;
lblId.ForeColor = System.Drawing.Color.Green;
}
}
}