为什么它发送邮件两次?

Why does It send a mail twice?

我有一个程序可以自动向我数据库中的人发送邮件。我正在使用此代码将人们带到数据 table:

private DataTable verileri_cek() 
{
    consql.Open();
    string kayit = "SELECT * from kisiler where 
        DATEPART(DAY,dogumtarihi)=DATEPART(DAY,GETDATE()) and 
        DATEPART(MONTH,dogumtarihi)=DATEPART(MONTH,GETDATE())";
    SqlCommand komut = new SqlCommand(kayit, consql);
    SqlDataAdapter da = new SqlDataAdapter(komut);
    DataTable dt =new DataTable(); 
    da.Fill(dt);
    consql.Close();
    return dt;
}

那我要发邮件给数据table上的人。我的两封不同的电子邮件必须收到两封电子邮件。但是它为一个发送了两次。为什么? 这是我发送邮件的代码部分:

private void Saat10()
{
    DataTable dt=verileri_cek();

    if (dt.Rows.Count > 0)
    {
        SmtpClient client = new SmtpClient();
        MailMessage mesaj = new MailMessage();

        for (int i = 0; i < dt.Rows.Count; i++)
        {
            if (dt.Rows[i]["durum"].ToString() == "Akademik")
            {
                mesaj.IsBodyHtml = true;
                mesaj.Subject = "Doğum Günü";
                mesaj.Body = "Sayın Akademik Personelimiz" + dt.Rows[i]["isim"].ToString() + " " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";

             }
             else
             {

                 mesaj.IsBodyHtml = true;
                 mesaj.Subject = "Doğum Günü";
                 mesaj.Body = "Sayın İdari Personelimiz" + " " + dt.Rows[i]["isim"].ToString() + "  " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";

             }
             mesaj.To.Add(dt.Rows[i]["mail"].ToString());
             client.Send(mesaj);

         }
     }

 }

你能帮帮我吗?

您必须为每个用户创建一个新的 MailMessage 对象:

 private void Saat10()
 {
    DataTable dt=verileri_cek();

    if (dt.Rows.Count > 0)
    {
        SmtpClient client = new SmtpClient();
        MailMessage mesaj = new MailMessage();

        for (int i = 0; i < dt.Rows.Count; i++)
        {
           mesaj = new MailMessage();

           // all other code
        }
    }

  }

首先,我建议您在每次实际发送邮件之前打印您收到的邮件。当然你也可以调试。在您的示例中,您需要在 for 循环内创建消息。

for (int i = 0; i < dt.Rows.Count; i++)
{
     MailMessage mesaj = new MailMessage();
     if (dt.Rows[i]["durum"].ToString() == "Akademik")
     {
           mesaj.IsBodyHtml = true;
           mesaj.Subject = "Doğum Günü";
           mesaj.Body = "Sayın Akademik Personelimiz" + dt.Rows[i]["isim"].ToString() + " " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";


     }
     else
     {
           mesaj.IsBodyHtml = true;
           mesaj.Subject = "Doğum Günü";
           mesaj.Body = "Sayın İdari Personelimiz" + " " + dt.Rows[i]["isim"].ToString() + "  " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";

     }
     mesaj.To.Add(dt.Rows[i]["mail"].ToString());
     client.Send(mesaj);

}

如果我正确理解了您的意思,并且您希望返回的每一行都有一条新消息 table,那么您需要移动:

MailMessage mesaj = new MailMessage();

..进入你的 For..Loop 而不是在你检查是否有行之后。

for (int i = 0; i < dt.Rows.Count; i++)
{
    MailMessage mesaj = new MailMessage();

    //< rest of your code here>

    mesaj.To.Add(dt.Rows[i]["mail"].ToString());
    client.Send(mesaj);
}