Ana içeriğe atla

SQL Server Mail Hizmetini Kullanmak

Merhaba;

Bu makalemde sql server üzerinden nasıl mail gönderebileceğimiz konusunda bilgi sahibi olmaya çalışacağız.bilgi sistemleri ortamında haberleşmenin temel yollarından birisi de e-mail dir kuşkusuz.büyük çapta bir proje geliştiriyorsanız kullanıcıları mail ile çeşitli konularda bilgilendirmek isteyebilirsiniz.bu makalenin yazımında bu kriter göz önüne alınmıştır.


SQL Server ortamında mail gönderebilmek için kullanabileceğimiz sp_sendmail Prosedürü bulunmaktadır.Bu prosedür SQL Server ile beraber gelmektedir.Prosedürü kullanabilmek için Database Management içerisinden Database Mail özelliğini aktif etmeniz ve geçerli bir hesap tanımı yapmanız gerekmektedir.Lakin prosedür tarafından gönderilen mailler bu Mail hesabı üzerinden gitmektedir. "Send Test Mail" diyerek hesap ayarlarınızın doğruluğunu kontrol edebilmeniz mümkündür.


Aşağıdaki T-SQL Kod parçası sp_sendmail fonksiyonunun kullanımına Örnektir;


CREATE TRIGGER [dbo].[MailTrigger] 
ON [dbo].[FATURALAR]
AFTER INSERT -- hangi işlemlerde triggerin çalışacağını belirliyoruz, insert, update, delete gibi
AS
DECLARE @SiraNo INT 
DECLARE @FaturaNo NVARCHAR(50)
DECLARE @Icerik NVARCHAR(50)
BEGIN

  Select @SiraNo = SiraNo From Inserted
  Select @FaturaNo = Cari From Inserted
  set @Icerik =CAST(@SiraNo AS NVARCHAR) + 'Numaralı Fatura Ödemesi Gerçekleştirildi'

exec msdb.dbo.sp_send_dbmail
@profile_name='MAILPROFILE', 
@recipients='ALICI ADRESLERİ','ALICI ADRESİ2','ALICI ADRESİ3'
@subject='EMAİL KONUSU', 
@body=@Icerik -- EMAİL İÇERİĞİ
END
GO

Burada Bir Mail trigger'ı tanımlanmış ve FATURALAR tablosuna atanmıştır.Faturalar tablosuna yapılan kayıt(INSERT) sonrasında mail trigger'ı faaliyete geçecek ve "recipients" kısmında belirtilen mail adreslerine Tanımladığınız Mail Hesabı üzerinden mail gönderimi yapacaktır.

Bu Makalenin konusu olmamakla birlikte madem yazdık o zaman hatırlatmasınıda yapalım ;
Select @SiraNo = SiraNo From Inserted
Select @FaturaNo = Cari From Inserted

After INSERT Trigger'ı tanımladığımız için "From Inserted" tanımlaması ile INSERT edilen kaydın ilgili kolonlarındaki bilgileri almış olduk.

Bu Makalede yanlızca Database Mail üzerinden Mail gönderimii incelenmiş ve Database Mail Yapılandırmasını bildiğiniz varsayılmıştır.Database Mail yapılandırması için Aşağıdaki Kaynaklara Göz atabilirsiniz.



Yorumlar

Bu blogdaki popüler yayınlar

PAYTR SANAL POS ASP.NET C# Entegrasyonu

merhaba, bu makalede sizlere PAYTR Sanal pos yapısını .NET üzerinde nasıl çalıştıracağımız ile ilgili bilgi aktarmaya çalışacağım. Ücretsiz başlangıç sağlaması ve sabit ödeme almaması sebebiyle düşük bütçeli e-ticaret yapmak isteyen kişilerin tercih ettiği PAYTR Sanal pos entegrasyonu temelde PHP üzerine kurulmuş. Dolayısıyla .net ile e-ticaret yazmaktaysanız bu sizi bir hayli zorluyor zira firma ile birçok görüşme yapmama rağmen sağlıklı bir .net örneklemesi bulamadım. Baktım olacak gibi değil, sonunda oturdum kendi entegrasyonumu kendim yazdım :). aşağıda detaylı olarak bulabilirsiniz. //using satırlarımızı ekleyelim; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Text; using System.Web; using System.Web.Script.Serialization; using System.Web.UI; using System.Web.UI.WebControls; //aşağıdaki sabit PAYTR Fonksiyon...

Devexpress SchedulerControl Kullanımı

Uzun bir aradan sonra merhaba; Sizlere bu makalede Devexpress ürününün en karmaşık kontrollerinden biri olan SchedulerControl nesnesinin kullanımı açıklamaya çalışacağım. Scheduler kontrol adındanda anlaşılacağı üzere tarihsel işlemleri görsel hale getirebileceğimiz detaylı bir kontroldür.zamanlamalı olarak randevu,görev,işlem vb. kavramları scheduler kontrol nesnesiyle kullanabiliriz.bunlarlada sınırlı değil tabiki.isterseniz Microsoft Outlook Takviminede bağlayabilir ve işlem kapsamınızı genişletebilirsiniz.Lafı fazla uzatmadan kodlamaya geçelim isterseniz. bu makaledeki bağlantı ve işlem şekilleri tamamen C# kodları ile yapılmaktadır.dataset vb. kontrolleri kullanmadım. yeni bir windows forms Projesi açalım ve boş bir forma schedulercontrol nesnesini sürükleyip bırakalım. kontrol ekranımıza yerleştiğinde alt kısımda SchedulerStorage isimli nesneyi göreceksiniz.SchedulerStorage SchedulerControl'ün çalışması için gerekli bir nesnedir zira veri işlemleri SchedulerStorage ...

Devexpress ASPxGridView içerisinde ASPxPopupControl Kullanımı

Merhaba, bu makalede sizlere; ASPxPopupControl  nesnesinin ASPxGridView  ile nasıl kullanacağına dair bilgi vermeye çalışacağım. Proje ortamında en sık karşılaştığımız işlemlerden biri, grid üzerinde düzenleme yapabilmektir.  Aslında standartta ASPxGridView  sizlere bu özelliği zaten kendi Edit modları ile sağlamakta. Fakat ASPxGridView üzerinde barındırılmayan ama bu veriler ile ilişkili olan işlemleri gerçekleştirmek için böyle bir yapıya ihtiyacımız var. Örneğin,  öğrencilerin not bilgilerini görüntülediğiniz Grid nesnesi üzerinde, sınav tarihlerini düzenlemek isteyebilirsiniz. İşte bu gibi durumlarda ASPxPopupControl kullanmamız gerekmekte. Örnekte (öğrencilere ait basit birkaç bilgi ile işlem gerçekleştireceğiz) bu işlemleri Client-Side desteğiyle nasıl gerçekleştirebiliriz ona bakalım; İlk olarak aşağıdaki gibi bir html tasarım oluşturalım;