每次提交,为什么在数据库中出现了两篇相同文章(郁闷中…………)

amoo 2002-11-04 01:19:42
我做论坛使用了frame就是知道那里出问题了,打开datagrid的分页功能,点一次下一页出现一下跳过两页!

private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if((int)(Page.Session["IsGood"])==0)
{
DisplayThd.NavigateUrl="display.aspx?subid="+Request.QueryString["subid"];
}
else
{
DisplayThd.NavigateUrl="jinghua.aspx?subid="+Request.QueryString["subid"];
};
strcon=ConfigurationSettings.AppSettings["eForum"];
}

#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.cn = new System.Data.OleDb.OleDbConnection();
this.Button1.Click += new System.EventHandler(this.PostBtn_Click);
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion

protected void PostBtn_Click(object sender, System.EventArgs e)
{
if(Page.IsValid)
{
cn=new OleDbConnection(strcon);
cn.Open();
string strSQL="INSERT INTO Threads ([SubId],[Subject],[NickName],[SendTime],[Body],[Length])"+
" VALUES (@SubId,@Subject,@NickName,@SendTime,@Body,@Length)";
OleDbCommand cmd=new OleDbCommand(strSQL,cn);
cmd.Parameters.Add(new OleDbParameter ("@SubId",OleDbType.Integer,4));
cmd.Parameters["@SubId"].Value = Request.QueryString["subid"];

cmd.Parameters.Add(new OleDbParameter ("@Subject",OleDbType.VarChar,40));
cmd.Parameters["@Subject"].Value = Subject.Text;

cmd.Parameters.Add(new OleDbParameter ("@NickName",OleDbType.VarChar,20));
cmd.Parameters["@NickName"].Value =Page.Session["NickName"].ToString();

cmd.Parameters.Add(new OleDbParameter ("@SendTime",OleDbType.VarChar,20));
cmd.Parameters["@SendTime"].Value =DateTime.Now.ToString();

cmd.Parameters.Add(new OleDbParameter ("@Body",OleDbType.LongVarChar,65535));
cmd.Parameters["@Body"].Value = body.Text;

cmd.Parameters.Add(new OleDbParameter ("@Length",OleDbType.Integer,4));
cmd.Parameters["@Length"].Value = body.Text.ToString().Length;

cmd.ExecuteNonQuery();
cn.Close();
t1.Visible=false;
t2.Visible=false;
Response.Write(" <hr><p><center>");
Response.Write("<h2>恭喜!您的文章已经张贴到论坛中!<h2>");
if((int)(Session["IsGood"])==0)
{
Response.Write("<b> <font size=+2>");
Response.Write("<a href=display.aspx?subid="+Request.QueryString["subid"]+">");
Response.Write("返回普通区</a></font></b>");
Response.Write("</center><p><hr>");

}
else
{
Response.Write("<b><font size=+2>");
Response.Write("<a href=jinghua.aspx?subid="+Request.QueryString["subid"]+">");
Response.Write("返回精华区</a></font></b>");
Response.Write("</center><p><hr>");
}
}
}

}
}
...全文
54 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
amoo 2002-11-06
  • 打赏
  • 举报
回复
不好意思,麻烦大家乐
原来我在事件里出发了一次,又在代码中出发了一次,谢谢大家的热心帮助
killerwc 2002-11-04
  • 打赏
  • 举报
回复
楼主:我支持你!
http://expert.csdn.net/Expert/topic/1138/1138631.xml?temp=.4322016
龙腾九霄 2002-11-04
  • 打赏
  • 举报
回复
agree with visualcpu
ele_faint 2002-11-04
  • 打赏
  • 举报
回复
你的代码兑不上号阿
visualcpu 2002-11-04
  • 打赏
  • 举报
回复
话句心里话,你这样贴出一大堆代码,是没有什么人看的,因为好难看的清,你应该贴主要的几行代码,!
像你这种错误,你应该跟踪一下翻页时的那些代码,就可以找到!
希望你能成功!
Aaron_Lau 2002-11-04
  • 打赏
  • 举报
回复
你可以用Debug跟踪一下,找出错误的位置。估计是你在点下一页的时候调用了两次翻页的功能。

62,074

社区成员

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

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

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

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