27 Ocak 2017 Cuma

SQL ile C# 'a kod oluşturma -2 (Tembellik SQL'i )


Merhaba,

Diyelim ki;
Veritabanımdaki tüm tablolarımda aşağıdaki anlamda alanlarım var.


* durum ( 0 ise pasif, 1 ise aktif, 2 aktif ama görülmez,listelenmez, 3 ise silindi olacak.. )
* oluşturma zamanı
* oluşturan kullanıcı
* güncelleme zamanı
* güncelleyen kullanıcı
* silme zamanı
* silen kullanıcı


Projemde LINQ kullanıyorum ve bu alanları eklemek kodda ilerledikten sonradan aklıma geldi.
Tüm LINQ CRUD methodlarını bulup bu alanları eklemek zahmetli olacağından, LINQ Datacontext classına
aşağıdaki gibi insert, update, delete override methodlarını yazarak bu işi halledeceğiz...

Ancak burada da tembellik damarı bastırdı, tüm tablolar için bunları tekrar kopyala ismini değiştir kim uğraşacak en iyisi
SQL veya Excel kullanarak tablo isimlerine göre bu kodu çoklamak.
Burada ben T-SQL cursor kullanarak yukardaki alanların geçtiği tüm tablo isimlerine göre bu kod bloğunu çoklattım.


SQL Management studio'da sonucu grid olarak gösterirsek satır sonu ifadeleri çalışmıyor tüm kod tek satır halinde oluşuyor.
Text kısmında göster dersek sonuç olarak ortaya çıkan metin uzun olduğundan burada anlamsız bir şekikde eksik gözüküyor.
O yüzden sql'i run etmeden önce File (Dosyada görüntüle) yi seçeceğiz..

Çoklamak istediğimiz kod bloğu (sadece bir tablo için ) şu şekilde :


partial class DatabaseContext
{

#region "TABLO_ABC"

partial void UpdateTABLO_ABC(TABLO_ABC instance)
{

instance.DATE_UPDATED = System.DateTime.Now;
instance.USER_UPDATED = Global.Instance.UserId;
this.ExecuteDynamicUpdate(instance);
}

partial void InsertTABLO_ABC(TABLO_ABC instance)
{
instance.DATE_CREATED = System.DateTime.Now;
instance.USER_CREATED = Global.Instance.UserId;
instance.STATUS = 1; // yeni eklenen kayıtlarda durumu 1 yapıyoruz...
this.ExecuteDynamicInsert(instance);
}

partial void DeleteTABLO_ABC(TABLO_ABC instance)
{
instance.DATE_DELETED = System.DateTime.Now;
instance.USER_DELETED = Global.Instance.UserId;
instance.STATUS = 3; //silme işlemi gerçekleştirilmek istenince durum=3 yapıp biz update yönlendiriyoruz.
//ekranda sadece durum=1 ler geldiğinden kullanıcı bu satırı görmüyor..
this.ExecuteDynamicUpdate(instance);
}

#endregion

}



Bu override methodlarımızı, LINQ'te veritabanı şemasını oluşturduğumuzda ekrana ayrı tabda açılan .cs uzantılı boş override DatabaseContext class'ına yazacağız. Daha sonraki veritabanı şema düzenlemeleri bu dosyadaki eklenti-override metodlarımızı silmiyor..

Bizim tüm tablolar için çoklamak istediğimiz kısım #region #endregion kısmı

Burda dinamik olarak bu metni tüm tablolar için güncellemek için sadece yapmamız gereken tablo isimlerini depiştirmek. Çünkü diğer kodların
hepsi tüm tablolar için aynı olacak. Bu yüzden T-SQL de, bu kod bloğunu tablo isimlerinin yerine yazarak nvarchar(MAX) tipinde
@SQL değişkenine atıyoruz.

Sonra içinde yukarıdaki sütunlardan birisi geçen tüm tablolarımızın isimlerini declare cursor ile select ediyoruz.
Her cursor döngüsünde bu @SQL değişkenindeki ifadesini cursor'ün sıradaki satırındaki tablo ismi ifadesi ile değiştirip sonucu
nvarchar(MAX) tipindeki @tmp değişkenine atıyoruz.
Sonrada bu değeri print ile dosyaya yazdırıyoruz...

Oluşan dosyayı .txt uzantısı ile kaydederseniz içeriğini kopyalayıp .cs dosyasına yapıştırabilirsiniz.

Yardımcı T-SQL bloğumuz..... :



/* çalıştırmadan önce sonucun dosyada gösterilmesi için yukarıdan Result to File (CTRL + SHIFT + F) seçiniz.. */

-- bazı tabloları istisna ederek içinde USER_DELETED sütunu geçen tüm tabloları cursor'e select ediyoruz..
declare c Cursor for select name
from sys.tables t where type='U'
and exists(select column_id from sys.columns where object_id=OBJECT_ID(t.name,'U')
and name='USER_DELETED')
and t.name not in ('_tmp','sysdiagrams','ISTISNA_TABLO','PARAM_TABLO')

open c

-- değişken tanımları
declare @newLine AS CHAR(2) = CHAR(13) + CHAR(10)
declare @table nvarchar(30)
declare @SQL nvarchar(MAX)
declare @tmp nvarchar(MAX)

-- başına ve sonuna ' koyarak tablo ismi olarak değiştirilmiş kod bloğumuzu @SQL değişkenine atıyoruz..
set @SQL='
#region ""

partial void Update( instance)
{

instance.DATE_UPDATED = System.DateTime.Now;
instance.USER_UPDATED = Global.Instance.UserId;
this.ExecuteDynamicUpdate(instance);
}

partial void Insert( instance)
{
instance.DATE_CREATED = System.DateTime.Now;
instance.USER_CREATED = Global.Instance.UserId;
instance.STATUS = 1; // yeni eklenen kayıtlarda durumu 1 yapıyoruz...
this.ExecuteDynamicInsert(instance);
}

partial void Delete( instance)
{
instance.DATE_DELETED = System.DateTime.Now;
instance.USER_DELETED = Global.Instance.UserId;
instance.STATUS = 3; //silme işlemi gerçekleştirilmek istenince durum=3 yapıp biz update yönlendiriyoruz.
//ekranda sadece durum=1 ler geldiğinden kullanıcı bu satırı görmüyor..
this.ExecuteDynamicUpdate(instance);
}

#endregion

}

'
-- ile tablo ismini al..
fetch from c into @table
while @@FETCH_STATUS!=-1
begin
-- ifadelerini cursorün sıradaki tablo ismi ile değiştir..
set @tmp=REPLACE(@SQL,'',@table)

-- sonucu dosyaya yazdır
print @tmp

--gerekmeyebilir.. bir satırsonu eklemek içi
print @newLine

-- cursor'ü ilerlet... >>>
fetch from c into @table
end


-- kapat yoket...
close c
deallocate c

/*
sql'i çalıştırınca ekrana gelen kaydet kısmında dosya tipi tüm dosyalar dosya ismi sonuc.txt yapabilirsiniz..
dosya içeriğini alıp .cs dosyanıza yapıştırın..
*/




Hiç yorum yok: