Ana içeriğe atla

T-SQL Application Name(APP_NAME) ile Aktif Uygulama Adını Almak

Merhaba,

bu makalede sizlere veritabanı üzerinde işlem gerçekleştirirken,bu işlemi hangi uygulamanın gerçekleştirdiğini sql tarafında yakalayıp nasıl kayıt altına alabileceğimizi göstereceğim.bu sayede en başta hata kayıtları olmak üzere birçok işlemi daha da detaylandırabilir ve kolay yönetilebilir hale getirebiliriz.



Sql server üzerinde işlem yapan uygulamayı

SELECT APP_NAME()
sorgusu ile yakalayabilmemiz mümkündür.

SQL Server arabirimi üzerinde bu sorguyu çalıştırdığınızda sonuç olarak size ;

'Microsoft SQL Server Management Studio - Query' metnini döndürecektir.


aynı işlemi uygulamalarımızda da kullanarak istediğimiz sonuca ulaşabiliriz.


Şöyle Ki ;

aşağıdaki create script'i kullanarak yeni bir tablo oluşturalım;
CREATE TABLE [dbo].[Hesap](
 [MusteriId] [int] IDENTITY(1,1) NOT NULL,
 [BankaAdi] [nvarchar](50) NULL,
 [HesapNo] [nvarchar](50) NULL,
 [KrediKarti] [bit] NULL,
 [KrediKartiNo] [nvarchar](50) NULL,
 CONSTRAINT [PK_Hesap] PRIMARY KEY CLUSTERED 
(
 [MusteriId] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

GO

tablomuzu oluşturduk.şimdi de bağlantımız için bir connectionstring yapılandıralım;
Data Source=127.0.0.1;Initial Catalog=test_db;Integrated Security=True;User ID=sa;Password=sapass;Connect Timeout=30;Encrypt=False; Pooling=true;Application Name='ornekProgram'; Packet Size=32000;

şimdi de log tutacağımız tablomuzu oluşturalım;

CREATE TABLE [dbo].[TBLLog](
 [Kullanici] [nvarchar](50) NULL,
 [KayitZamani] [datetime] NULL
) ON [PRIMARY]

GO

log tablomuzuda oluşturduktan sonra Hesap tablomuza bir adet INSERT Trigger'ı ekleyelim.Bu sayede Hesap tablomuza her kayıt atıldığında INSERT Trigger'ı çalışacak ve Log tablomuza kaydı yapan uygulamayı ve kayıt tarihini atacaktır.

CREATE TRIGGER [dbo].[TriggerLog]
   ON  [dbo].[Hesap]
   AFTER  INSERT
AS 
BEGIN
declare @AppName nvarchar(50)=(SELECT APP_NAME())
declare @Zaman datetime =(SELECT GETDATE())
INSERT INTO TBLLog(Kullanici,KayitZamani) VALUES(@AppName,@Zaman )
END

csharp tarafında Hesap tablosuna yaptığınız her kayıt için bundan böyle log tablosunda verilerin geldiğini göreceksiniz.bu basit bir kısmıydı.sizler verdiğim örneği daha da geliştirerek farklı sorunlara çözüm bulabilirsiniz.




Kolay Gelsin


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

ASP.NET Sayfalar arası veri taşıma işlemleri

merhaba; bu yazımda sizlere asp.net üzerinde sayfalar arasında veri taşıma işlemlerinden bahsetmek istiyorum.hepimizin bildiği gibi uygulamarımızda sayfalarımız arası haberleşmeler büyük önem arzetmektedir.bazı sayfalarda bazı işlemlerin yerine getirilebilmesi için diğer sayfalardan gelecek verilere ihtiyaç duyulabilir(GET).ASP.NET üzerinde veri taşıma işlemleri aşağıdaki şekillerde yapılabilir. 1-)QueryString : en yaygın ve basit kullanıma sahip olanıdır.istenilen verileri sayfayı post ettiğiniz zaman yönlendirildiğiniz sayfaya URL üzerinden taşır. Kullanımı : a sayfasından b sayfasına isim taşıyalım. a sayfasında linkinizi şu şekilde değiştirirseniz: Response.Redirect("gidileceksayfa.aspx?isim=can"); Tarayıcınızın URL kısmına baktığınızda: www.siteadi.com/b.aspx?isim=can olarak görürsünüz.a sayfasından veri aktarımı tamamlanmıştır.bundan sonraki adım b sayfasından gelen veriyi almaktan ibarettir.o da şu şekilde yapılır: b sayfasında "isim" adında b

ASP.NET - Aynı anahtara sahip bir girdi zaten var.

Eğer ASP.NET ile uğraşırken böyle bir hata aldıysanız aşağıdaki paragraf tam size göre; " Aynı anahtara sahip bir girdi zaten var."  hatasının sebebi sayfanızdaki birden çok nesne için  ClientIDMode Özelliğini " Static " olarak ayarlamanızdan kaynaklanmaktadır.Normal şartlarda sayfa içerisindeki her kontrolün ID si birbirinden farklı olmalıdır.bu tanımı düzelttiğinizde sorununda çözüldüğünü göreceksiniz.Burdaki problem şu ki visual studio hatayı farklı satırlarda veriyor.buda özellikle ilk defa böyle bir hata ile karşılaşıyorsanız çözümü inanılmaz zorlaştırıyor.