首页 > 解决方案 > 更新网站中的用户资料

问题描述

在我由 asp.net 制作的网站中,如果旧密码正确,我们可以更新用户的电子邮件地址、密码、地点和个人信息。现在我要做的是登录,然后使用此代码进行更新:

 protected void update_profile(object sender, EventArgs e)
    {
        string constr = ConfigurationManager.ConnectionStrings["Khulna_website"].ConnectionString;
        using (SqlConnection connection = new SqlConnection(constr))
        {
            string user_email = (string)(Session["User"]);
            string pass = encrypt_pass(old_password.Text);
            if (pass != (string)(Session["Password"]))
            {
                pass_err_message.Text = "Wrong password";
                pass = (string)Session["Password"];
            }
            else
            {
                pass = encrypt_pass(new_password.Text);
            }
            string insertQuery = "update dbo.users set user_password=@new_password, user_place = @new_place, user_about=@new_about where user_email =" +user_email;
            SqlCommand com = new SqlCommand(insertQuery, connection);
            connection.Open();
            com.Parameters.AddWithValue("@new_password", pass);
            com.Parameters.AddWithValue("@new_about", new_about.Text);
            com.Parameters.AddWithValue("@new_place", new_place.Text);
            try
            {
                com.ExecuteNonQuery();
                upload_err_message.Text = "Successfully uploaded";
                connection.Close();
            }
            catch (Exception ex)
            {
                profile_settings_err_message.Text = "Update error: " + ex.Message;
            }

        }

    }

但是当我尝试更新时它说:更新错误:无法绑定多部分标识符“abcde@gmail.com”。我的会话消失了!我想可能是由于外键,所以我删除了数据库的所有外键,但它仍然在发生。这里有什么问题?

编辑:我已经添加了外键,因为我需要它们来删除级联。我只是删除了它们,看看它是否有效。

标签: asp.netsql-update

解决方案


我只是猜测,但我相信您的问题会在这里找到:

"... user_email =" +user_email;

尝试做类似的事情

"... user_email = @email";
com.Parameters.AddWithValue("@email", user_email);

这是更好的方法......但是,如果您想变得懒散,您应该能够将电子邮件用单引号括起来。

"... user_email = '" + user_email + "'";

我希望这有帮助!


推荐阅读