AccessTr.neT

Tam Versiyon: Sorgudaki Bilgileri Otomatik Tek Tek Mail Gönderme
Şu anda arşiv modunu görüntülemektesiniz. Tam versiyonu görüntülemek için buraya tıklayınız.
Sayfalar: 1 2
Sayın Hocalarım;

Accees üzerinden mail adresi bilgilerimi tanımlayarak Üye Datası Sorgusunda yer alan her üyenin verisini otomatik tek tek aşağıdaki şekilde üyelere mail olarak göndermek istiyorum. Kendi çalışmamı eklere yükledim bir tane tane örnek buldum onun formu çok güzel onu da çözemedim. 

Konuyu hiç bir alanda çözemedim yardımlarınızı bekliyorum.

Mail İçeriği 

Sayın üyemiz aidat bilgileriniz aşağıda yer almaktadır.
 
Dönem : Sorgudaki Ay
Tahakkuk : Sorgudaki Tahakkuk
Tahsilat: Sorgudaki Tahsilat
Kalan Borc : Sorgudaki Borc
eklemiş olduğunuz uygulamada(sizin) hiç mail gönderme çalışması yok, çözemediğin uygulamada ise hiç tablo yok, tablo yoksa uygulamada yok sayılır.
Size bilgi vermesi açısından, bir ışık tutması açısından formumuzda bulunan Mail Gönderme ile ilgili sonuçları gösteren linki ekliyorum. Umarım faydalı olur...
https://accesstr.net/search.php?action=r...order=desc
Sayın @onur_can hocamızın belirttiği üzere örneklerinizde değerlendirme yapmamızı ve çözüm önerisi sunmamızı gerektiren asli unsurlar yok. Ancak örnek tablonuzdan yola çıkarak sorgu sonuçlarını göndermek istediğiniz kişilerin mail adresleri ve diğer bilgilerinin tutulduğu cari kart verilerini içeren bir tablo oluşturmanız, sorgunuza bu tablodan email adreslerini dahil etmeniz doğru bir yaklaşım olacaktır ve buna göre örnek olarak aşağıdaki kod sorgunuzun sonuçlarını her bir kayıt için mail olarak gönderilmesini sağlayacaktır.
Sub SendMails()
    Dim ObjOutlook As Object, ObjMail As Object
    Dim db As DAO.Database
    Dim rst As DAO.Recordset
   
    Set db = CurrentDb()
    Set rst = db.OpenRecordset("SorguAdınz")    'Recordseti tanımla
   
    On Error Resume Next
    Set ObjOutlook = CreateObject("Outlook.Application")
    On Error GoTo 0
   
    If ObjOutlook Is Nothing Then   
        MsgBox "Outlook başlatılamadı. Lütfen Outlook'un yüklü ve açık olduğundan emin olun.", vbExclamation    'Outlook başlatılamazsa uyar (bunu genelde kullanmam ama geçen başka bir soruda önerilmiş mantıklı bulduğum için ekledim)
        Exit Sub
    End If
   
    Do Until rst.EOF    'Recordsetin son kaydına kadar kayıtları dolaş
        Set ObjMail = ObjOutlook.CreateItem(0)    'Yeni bir email oluşturur
       
        With ObjMail
            .To = "[AlıcıEpostaAdresi]"    'Alıcı e-posta adresi, sorgunuza ekleyeceğiniz mail alanını değişken olarak kullanabilirsiniz
            .Subject = "Üye Borç Bilgilendirmesi - " & rst!uyeno    'Email konusu (örneğin üye 1 için veya adı soyadını değişken olarak kullanabilirsiniz)
            .Body = "Sayın " & rst![adı soyadı] & "," & vbCrLf & vbCrLf & _
                    "Borç bilgilendirmeniz aşağıdaki gibidir:" & vbCrLf & _
                    "Ay: " & rst!ay & vbCrLf & _
                    "Tahakkuk: " & rst!tahakkuk & vbCrLf & _
                    "Tahsilat: " & rst!tahsilat & vbCrLf & _
                    "Borç: " & rst!borc & vbCrLf & vbCrLf & _
                    "İyi günler dileriz."    'Emailin mesaj içeriği
            .Send    'Emaili gönder
        End With
       
        rst.MoveNext    'sonraki kayda geç
    Loop
   
    rst.Close
    Set rst = Nothing
    Set db = Nothing
    Set ObjMail = Nothing
    Set ObjOutlook = Nothing
   
    'MsgBox "E-postalar başarıyla gönderildi.", vbInformation, "Email Gönderim Sonuç Bildirimi"    '(istenirse) işlem bittiğine dair mesaj göster
End Sub
Değerli hocalarım örneğimi tam olarak hazırladım TOPLU_MAİL formu ile alt formdaki her üyenin verisini üyelere tek tek göndermesini tasarladım lakin çalışmıyor.

deneme.com - deneme@deneme.com mail uzantısı ile denedim olmadı şuan örnekte GMAİL üzerinden göndermeyi deniyorum 2 aşamalı doğrulamada açık.

Yardımlarınızı bekliyorum.
SendMail fonksiyonunuzu aşağıdaki gibi değiştirin
Function SendMail()
    Dim db As DAO.Database
    Dim rs As DAO.Recordset
    Dim sayac As Integer
    Dim iMsg As Object, iConf As Object, Fields As Object
    Dim iConfURL As String

    On Error GoTo hata
   
    Set db = CurrentDb
    Set rs = db.OpenRecordset("EPOSTA")

    Do While Not rs.EOF
        Set iMsg = CreateObject("CDO.Message")
        Set iConf = CreateObject("CDO.Configuration")
       
        iConfURL = "http://schemas.microsoft.com/cdo/configuration/"
       
        With iConf.Fields
            .Item(iConfURL & "sendusing") = 2
            .Item(iConfURL & "smtpserver") = "smtp.gmail.com"
            .Item(iConfURL & "smtpserverport") = 465
            .Item(iConfURL & "smtpusessl") = True
            .Item(iConfURL & "smtpauthenticate") = 1
            .Item(iConfURL & "sendusername") = Me.txtmailadresi
            .Item(iConfURL & "sendpassword") = Me.txtmailsifre
            .Update
        End With

        With iMsg
            Set .Configuration = iConf
            .To = rs("EMAIL")
            .From = Me.txtGonderen & " <" & Me.txtmailadresi & ">"
            .Subject = Me.TxtKonu
            .TextBody = "TARİH: " & rs("TARIH") & vbCrLf & _
                        "AİDAT TAHAKKUK: " & rs("ATAHSILAT") & vbCrLf & _
                        "AİDAT TAHSİLAT: " & rs("ATAHAKKUK") & vbCrLf & _
                        "AİDAT BORC: " & rs("ABORC")
        End With

        iMsg.Send
       
        sayac = sayac + 1
        Me.Metin31 = sayac & ". Mail Gönderildi."
        rs.MoveNext
    Loop

    MsgBox sayac & " mail gönderimi başarılı.", vbInformation, "İşlem tamam"

    Set iMsg = Nothing
    Set iConf = Nothing
    Set Fields = Nothing
    rs.Close
    Set rs = Nothing

    Exit Function

hata:
    MsgBox "Mail gönderimi başarısız. Hata: " & Err.Description, vbCritical, "Hata oluştu."
    Debug.Print "CDO Hatası: " & Err.Description
End Function
https://security.google.com/settings/sec...ppasswords linki üzerinden Google uygulama şifrenizi oluşturun ve mail şifreniz yerine bu şifreyi girin. Referanslardan Microsoft CDO for Windows Library'nin etkin olduğundan emin olun. Ardından mail gönderebilirsiniz.
(09/11/2024, 21:17)atoykan yazdı: [ -> ]SendMail fonksiyonunuzu aşağıdaki gibi değiştirin
Function SendMail()
    Dim db As DAO.Database
    Dim rs As DAO.Recordset
    Dim sayac As Integer
    Dim iMsg As Object, iConf As Object, Fields As Object
    Dim iConfURL As String

    On Error GoTo hata
   
    Set db = CurrentDb
    Set rs = db.OpenRecordset("EPOSTA")

    Do While Not rs.EOF
        Set iMsg = CreateObject("CDO.Message")
        Set iConf = CreateObject("CDO.Configuration")
       
        iConfURL = "http://schemas.microsoft.com/cdo/configuration/"
       
        With iConf.Fields
            .Item(iConfURL & "sendusing") = 2
            .Item(iConfURL & "smtpserver") = "smtp.gmail.com"
            .Item(iConfURL & "smtpserverport") = 465
            .Item(iConfURL & "smtpusessl") = True
            .Item(iConfURL & "smtpauthenticate") = 1
            .Item(iConfURL & "sendusername") = Me.txtmailadresi
            .Item(iConfURL & "sendpassword") = Me.txtmailsifre
            .Update
        End With

        With iMsg
            Set .Configuration = iConf
            .To = rs("EMAIL")
            .From = Me.txtGonderen & " <" & Me.txtmailadresi & ">"
            .Subject = Me.TxtKonu
            .TextBody = "TARİH: " & rs("TARIH") & vbCrLf & _
                        "AİDAT TAHAKKUK: " & rs("ATAHSILAT") & vbCrLf & _
                        "AİDAT TAHSİLAT: " & rs("ATAHAKKUK") & vbCrLf & _
                        "AİDAT BORC: " & rs("ABORC")
        End With

        iMsg.Send
       
        sayac = sayac + 1
        Me.Metin31 = sayac & ". Mail Gönderildi."
        rs.MoveNext
    Loop

    MsgBox sayac & " mail gönderimi başarılı.", vbInformation, "İşlem tamam"

    Set iMsg = Nothing
    Set iConf = Nothing
    Set Fields = Nothing
    rs.Close
    Set rs = Nothing

    Exit Function

hata:
    MsgBox "Mail gönderimi başarısız. Hata: " & Err.Description, vbCritical, "Hata oluştu."
    Debug.Print "CDO Hatası: " & Err.Description
End Function
https://security.google.com/settings/sec...ppasswords linki üzerinden Google uygulama şifrenizi oluşturun ve mail şifreniz yerine bu şifreyi girin. Referanslardan Microsoft CDO for Windows Library'nin etkin olduğundan emin olun. Ardından mail gönderebilirsiniz.

Hocam çok teşekkür ederim elinize aklınıza sağlık sorunsuz çalıştı.
Sayfalar: 1 2