后自动刷新ASP.NET的GridView我需要更新GridView
发送电子邮件后,在表userTable
注册用户的列表。如何更新
GridView
从25个用户一次填充。
我发送电子邮件至25个用户第一,更新领域SendEmail
为ID user
,现在我需要更新GridView
和显示下一个25个用户等等。
我已经试过这个解决方案,但后发送电子邮件和更新领域SendEmail
为ID user
我看到的总是先25个用户。
我错过了什么?
这段代码有什么问题?
预先感谢您。
我的代码C#ASP网:
protected void btnSend_Click(object sender, EventArgs e)
{
try
{
SmtpClient smtpClient = new SmtpClient();
System.Net.Mail.MailMessage mailMessage = new System.Net.Mail.MailMessage();
lbltotalcount.Text = string.Empty;
foreach (GridViewRow grow in grvCustomers.Rows)
{
try
{
ID = grow.Cells[0].Text.Trim();
name = grow.Cells[1].Text.Trim();
email = grow.Cells[2].Text.Trim();
//Send email;
using (OdbcConnection conn =
new OdbcConnection(ConfigurationManager.ConnectionStrings["cs"].ConnectionString))
{
sql1 = " UPDATE userTable SET `SendEmail` = 1 WHERE ID = ?; ";
using (OdbcCommand cmd = new OdbcCommand(sql1, conn))
{
try
{
conn.Open();
cmd.Parameters.AddWithValue("param1", ID.ToString());
cmd.ExecuteNonQuery();
Response.Write(sql1 + "<br /><br />");
btnBind.DataBind();
}
catch (Exception ex)
{
Response.Write("Send Email Failed." + ex.Message);
}
finally
{
conn.Close();
}
}
}
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
protected void btnBind_Click(object sender, EventArgs e)
{
sql = " SELECT * from userTable WHERE `SendEmail` = 0 LIMIT 25; ";
using (OdbcConnection conn =
new OdbcConnection(ConfigurationManager.ConnectionStrings["cs"].ConnectionString))
{
conn.Open();
using (OdbcCommand cmd = new OdbcCommand(sql, conn))
{
try
{
OdbcDataAdapter adp = new OdbcDataAdapter(cmd);
DataSet ds = new DataSet();
adp.Fill(ds);
grvCustomers.DataSource = ds;
grvCustomers.DataBind();
lbltotalcount.Text = grvCustomers.Rows.Count.ToString();
}
catch (Exception ex)
{
Response.Write("Send Email Failed." + ex.Message);
}
finally
{
conn.Close();
}
btnBind.Visible = false;
}
}
}
edit #1
protected void btnBind_Click(object sender, EventArgs e)
{
BindGrid();
}
protected void btnSend_Click(object sender, EventArgs e)
{
try
{
SmtpClient smtpClient = new SmtpClient();
System.Net.Mail.MailMessage mailMessage = new System.Net.Mail.MailMessage();
lbltotalcount.Text = string.Empty;
foreach (GridViewRow grow in grvCustomers.Rows)
{
try
{
ID = grow.Cells[0].Text.Trim();
name = grow.Cells[1].Text.Trim();
email = grow.Cells[2].Text.Trim();
//Send email;
using (OdbcConnection conn =
new OdbcConnection(ConfigurationManager.ConnectionStrings["cs"].ConnectionString))
{
sql1 = " UPDATE userTable SET `SendEmail` = 1 WHERE ID = ?; ";
using (OdbcCommand cmd = new OdbcCommand(sql1, conn))
{
try
{
conn.Open();
cmd.Parameters.AddWithValue("param1", ID.ToString());
cmd.ExecuteNonQuery();
Response.Write(sql1 + "<br /><br />");
BindGrid();
}
catch (Exception ex)
{
Response.Write("Send Email Failed." + ex.Message);
}
finally
{
conn.Close();
}
}
}
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
protected void BindGrid();
{
sql = " SELECT * from userTable WHERE `SendEmail` = 0 LIMIT 25; ";
using (OdbcConnection conn =
new OdbcConnection(ConfigurationManager.ConnectionStrings["cs"].ConnectionString))
{
conn.Open();
using (OdbcCommand cmd = new OdbcCommand(sql, conn))
{
try
{
OdbcDataAdapter adp = new OdbcDataAdapter(cmd);
DataSet ds = new DataSet();
adp.Fill(ds);
grvCustomers.DataSource = ds;
grvCustomers.DataBind();
lbltotalcount.Text = grvCustomers.Rows.Count.ToString();
}
catch (Exception ex)
{
Response.Write("Send Email Failed." + ex.Message);
}
finally
{
conn.Close();
}
btnBind.Visible = false;
}
}
}
是您提交后重新绑定再次抓住你的数据吗? – Kritner 2014-10-02 18:53:02
发送电子邮件后,您需要重新绑定GridView。 – 2014-10-02 18:53:13
重新绑定网格对此无济于事。发送邮件后..获取下25条记录并将这25行再次绑定到网格。 – Rahul 2014-10-02 18:54:13