简单一段代码,怎么插入数据库两次了?

Aimar168 2004-12-13 10:05:50
if(Page.IsValid)
{
string username = txtUsername.Text;
string password = FormsAuthentication.HashPasswordForStoringInConfigFile (txtPassword.Text,"md5");
string email = txtEmail.Text;
string connString = "server=(local);database=guestbook;uid=sa;pwd=321560;";
SqlConnection conn = new SqlConnection(connString);
string sql = "INSERT INTO users(username,password,email) values('"+username+"','"+password+"','"+email+"')"; //怎么同时插入一模一样的纪录?
conn.Open();
SqlCommand cmd = new SqlCommand(sql,conn);
cmd.ExecuteNonQuery();
conn.Close();
Response.Write("<script language='javascript'>{alert('注册成功!');window.location.href='default.aspx'}</script>");
}
...全文
202 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
Aimar168 2004-12-14
  • 打赏
  • 举报
回复
我是写到注册按钮中的
protected void sbt_click(object sender, System.EventArgs e)
{......}
yt_net 2004-12-14
  • 打赏
  • 举报
回复
我建议你把这段代码写道按钮事件中,否则还会出现这种情况的,因为当重新定位到本届面时又执行了一次插入
Aimar168 2004-12-14
  • 打赏
  • 举报
回复
原因找到了:conn.Close();的后面不管加Response.end();还是Server.Transfer("default.aspx");
都只要一条.
跳转(Transfer)别的页面或者提交后结束执行(Response.End();)本页面那就只有一条记录
否则重定位到本页面则有2条. 可有时候提交后回到本页面怎样避免插入2条记录??

这30分给前面的几位
谁帮我解决这个问题,再加30分
andrawsky 2004-12-14
  • 打赏
  • 举报
回复
单步到int numAff = cmd.ExecuteNonQuery();时numAff显示为1,数据库中也只有一条
然后结束关闭浏览器,数据库中有了2条!!

lblNum.Text = numAff.ToString();
后面加上这个Server.Transfer("default.aspx");
则数据库中始终只有1条纪录,不跳转不行吗????

Aimar168 2004-12-14
  • 打赏
  • 举报
回复
我不想Server.Transfer("default.aspx");
只想在本页中提示注册成功,可怎么总插入2条记录,又没有提交2次???
什么原因?
dcren118 2004-12-14
  • 打赏
  • 举报
回复
conn.Close();
在他的后面Response.end();
看看数据库里面是几条记录如果是一个那么就是其他地方的问题了
把这个改成if(Page.IsValid) 去掉看看是否还有类似的问题

liuyong_lll 2004-12-14
  • 打赏
  • 举报
回复
上边的说的^_^,真的是清楚
Aimar168 2004-12-14
  • 打赏
  • 举报
回复
单步到int numAff = cmd.ExecuteNonQuery();时numAff显示为1,数据库中也只有一条
然后结束关闭浏览器,数据库中有了2条!!

lblNum.Text = numAff.ToString();
后面加上这个Server.Transfer("default.aspx");
则数据库中始终只有1条纪录,不跳转不行吗????

whb147 2004-12-13
  • 打赏
  • 举报
回复
你单步测试看看是怎么运行的
这个代码没问题,
要看前面的逻辑,条件
Aimar168 2004-12-13
  • 打赏
  • 举报
回复
protected void sbt_click(object sender, System.EventArgs e)
{
string username = txtUsername.Text;
string password = FormsAuthentication.HashPasswordForStoringInConfigFile(txtPassword.Text,"md5");
string email = txtEmail.Text;
string connString = "server=(local);database=guestbook;uid=sa;pwd=321560;";
SqlConnection conn = new SqlConnection(connString);
string sql = "INSERT INTO users(username,password,email) values('"+username+"','"+password+"','"+email+"')";
conn.Open();
SqlCommand cmd = new SqlCommand(sql,conn);
int numAff = cmd.ExecuteNonQuery();
lblNum.Text = numAff.ToString(); //lblNum输出为1,怎么出入2条??
conn.Close();
//Response.Write("<script language='javascript'>{alert('注册成功!');window.location.href='default.aspx'}</script>");
}
Aimar168 2004-12-13
  • 打赏
  • 举报
回复
1. if(!Page.IsPostBack)改用if(!Page.IsPostBack),则数据没有插入数据库

2. int numAff = cmd.ExecuteNonQuery();
输出numAff为1,插入数据库却有2条??
vikingleo 2004-12-13
  • 打赏
  • 举报
回复
我认为你直接可以把语句写到click 事件中不用判断Page.IsValid
baya 2004-12-13
  • 打赏
  • 举报
回复
你先单步调试一下,看程序如何运行
vikingleo 2004-12-13
  • 打赏
  • 举报
回复
你为什么不把这段代码写到注册按纽里面去呢?

if(!Page.IsPostBack)
{
string username = txtUsername.Text;
string password = FormsAuthentication.HashPasswordForStoringInConfigFile (txtPassword.Text,"md5");
string email = txtEmail.Text;
string connString = "server=(local);database=guestbook;uid=sa;pwd=321560;";
SqlConnection conn = new SqlConnection(connString);
string sql = "INSERT INTO users(username,password,email) values('"+username+"','"+password+"','"+email+"')"; //怎么同时插入一模一样的纪录?
conn.Open();
SqlCommand cmd = new SqlCommand(sql,conn);
cmd.ExecuteNonQuery();
conn.Close();
Response.Write("<script language='javascript'>{alert('注册成功!');window.location.href='default.aspx'}</script>");
}

62,047

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧