保存到数据库,然后从数据库读取,数据不存在
本文关键字:数据库 数据 不存在 读取 然后 保存 | 更新日期: 2023-09-27 18:18:45
我有这个页面,用户可以修改它的信息。当页面加载时,它将用户信息填充到文本输入字段中。然后您可以更改您的信息并点击保存。数据应该保存到数据库中,并且由于刷新,这也应该反映在文本字段中。但它不会保存数据。如果我删除数据读取,则在点击按钮时保存数据,但当数据读取存在时,数据不保存。
这是"读取数据"部分的代码,这是在Page_Load():
string loggedInUser = System.Web.HttpContext.Current.User.Identity.Name;
SqlConnection ConnectDb = new SqlConnection("Data Source=serverHere;Initial Catalog=catalogHere;User ID=userNameHere;Password=passwordHere;"); //Opretter database connection string
SqlDataReader infoReader = null;
SqlCommand getUserInfo = new SqlCommand("SELECT firstName,lastName,age,city,contact,bio FROM UserInfo WHERE userName = @userName", ConnectDb);
getUserInfo.Parameters.Add("@userName", loggedInUser);
ConnectDb.Open();
infoReader = getUserInfo.ExecuteReader();
infoReader.Read();
{
tbInfoFirstName.Text = infoReader["firstName"].ToString();
tbInfoLastname.Text = infoReader["lastName"].ToString();
tbInfoAge.Text = infoReader["age"].ToString();
tbInfoCity.Text = infoReader["city"].ToString();
tbInfoKontakt.Text = infoReader["contact"].ToString();
tbInfoAbout.Text = infoReader["bio"].ToString();
};
ConnectDb.Close();
这是保存按钮的代码:
string loggedInUser = System.Web.HttpContext.Current.User.Identity.Name;
SqlConnection ConnectDb = new SqlConnection("Data Source=serverHere;Initial Catalog=catalogHere;User ID=userNameHere;Password=passwordHere;");
SqlCommand SavePersonInfo = new SqlCommand("UPDATE UserInfo SET firstName = @firstName,lastName = @lastName,age = @age,city = @city,contact = @contact,bio = @bio WHERE userName = @userName", ConnectDb);
SavePersonInfo.Parameters.AddWithValue("@firstName", tbInfoFirstName.Text);
SavePersonInfo.Parameters.AddWithValue("@lastName", tbInfoLastname.Text);
SavePersonInfo.Parameters.AddWithValue("@age", tbInfoAge.Text);
SavePersonInfo.Parameters.AddWithValue("@city", tbInfoCity.Text);
SavePersonInfo.Parameters.AddWithValue("@contact", tbInfoKontakt.Text);
SavePersonInfo.Parameters.AddWithValue("@bio", tbInfoAbout.Text);
SavePersonInfo.Parameters.AddWithValue("@userName", loggedInUser);
ConnectDb.Open();
SavePersonInfo.ExecuteNonQuery();
//Response.Redirect("Manage.aspx");
ConnectDb.Close();
如前所述,保存代码可以自己工作,但当读取代码也处于活动状态时则不能工作,例如:
我认为Page_Load事件是在PostBack事件按钮之前启动的。在这种情况下,读取的是旧数据再次填充字段,最后再次记录旧数据。你检查过了吗?
如果是,把你的代码放在Page_Load的If (IsPostBack!)中:
public void Page_Load() {
// ...
if (!IsPostBack) {
// code read the data
}
}