我正在尝试在ASP.NET中创建一个工作门户,该门户从用户那里获取个人信息并将其存储到数据库中。
数据库表具有这些列
name, fathername, nic, cell, email, city, province, district, dob,
address, disability, orphan
注册时,用户仅输入(名称,父亲名称,单元,cnic,dob)的值。用户成功注册后,他们必须登录,然后带他们到门户。门户网站具有一个标签容器,其中“个人信息”标签包含来自用户的个人信息。注册时输入的信息已经显示在文本框中,其余的将使用文本框和下拉列表输入。
问题是,当我尝试使用更新查询输入其余信息时,查询成功执行,并且下拉列表中的值被成功更新,但是文本框中的值被保存为数据库中的空白值。
这是我的代码:
protected void BtnSavePersonal_Click(object sender, EventArgs e)
{
// // inserting into database
conn = new SqlConnection();
conn.ConnectionString = connString;
string query = "UPDATE PersonalInfoTable SET cell = @cell, email = @email, city = @city, domprov = @domprov, domcity = @domcity, address = @address, religon = @religon, gender = @gender, occupation = @occupation, disability = @disability, occupation = @occupation WHERE cnic='" + Session["cnic"] + "'";
SqlCommand cmd = new SqlCommand(query, conn);
cmd.Parameters.AddWithValue("@cell", txtCell.Text);
cmd.Parameters.AddWithValue("@email", txtEmail.Text);
cmd.Parameters.AddWithValue("@city", txtCity.Text);
cmd.Parameters.AddWithValue("@domprov", dropDomProv.Text);
cmd.Parameters.AddWithValue("@domcity", dropDomCity.Text);
cmd.Parameters.AddWithValue("@address", txtAddr.Text);
cmd.Parameters.AddWithValue("@religon", dropReligon.Text);
cmd.Parameters.AddWithValue("@gender", dropGender.Text);
cmd.Parameters.AddWithValue("@occupation", txtOcc.Text);
cmd.Parameters.AddWithValue("@disability", dropDisable.Text);
cmd.Parameters.AddWithValue("@orphan", dropOrphan.Text);
Session["cnic"] = txtCnic.Text;
try
{
conn.Open();
Console.WriteLine(query);
cmd.ExecuteNonQuery();
Response.Redirect("Candidate Portal.aspx");
Response.Write("<script language=javascript>alert('Registration Successful.')</script>");
personalFill();
} // try
catch (SqlException ex)
{
Response.Write("<script language=javascript>alert('Registration Failed.')</script>");
} // catch
finally
{
conn.Close();
}
}
[另一个问题是,一旦我将下拉列表中的值保存到数据库中,我希望禁用某些下拉列表(即省,市,区),以便用户无法再次编辑该信息。我尝试了以下方法:
protected void editFalse()
{
txtName.Enabled = false; txtFName.Enabled = false; txtCnic.Enabled = false; txtDOB.Enabled = false;
while (dropDomProv.SelectedItem.ToString() != "-- Select --")
{
dropDomProv.Enabled = false;
}
while (dropDomCity.SelectedItem.ToString() != "-- Select --")
{
dropDomCity.Enabled = false;
}
while (dropReligon.SelectedItem.ToString() != "-- Select --")
{
dropReligon.Enabled = false;
}
while (dropDomProv.SelectedItem.ToString() != "-- Select --")
{
dropGender.Enabled = false;
}
}
texbox被禁用,但下拉列表未被禁用。我也尝试用if代替while,但是那也不起作用。
我解决了。原来的问题是我在页面加载功能中缺少回发检查。因此,更新查询中的值已被数据库中已存在的值删除,并因此给了我空白值。我刚刚添加了
if(!Page.IsPostBack)
{
}
到pageload函数,并添加了从数据库获取值并禁用其中的下拉菜单的功能。解决了我两个问题。