更新查询成功,但在SQL Server数据库中获得空值

问题描述 投票:0回答:1

我正在尝试在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,但是那也不起作用。

c# asp.net sql-server database-connection
1个回答
0
投票

我解决了。原来的问题是我在页面加载功能中缺少回发检查。因此,更新查询中的值已被数据库中已存在的值删除,并因此给了我空白值。我刚刚添加了

if(!Page.IsPostBack)
{
}

到pageload函数,并添加了从数据库获取值并禁用其中的下拉菜单的功能。解决了我两个问题。

© www.soinside.com 2019 - 2024. All rights reserved.