Linq Ve Transactionlar İle Conflictlerin Çözülmesi

2023-05-08

Veritabanları ile çalışırken, eşzamanlı transactionların doğru bir şekilde yönetilmesi ve veri bütünlüğünün korunması büyük önem taşır. LINQ (Language Integrated Query) ile veritabanı işlemlerinde transactionlar (transactions) kullanarak çakışmaların nasıl çözüleceği konusunda örnekler ve ve öneriler gösterilecektir.

Transactionlar (Transactions) Nedir?

Transactionlar, veritabanı üzerinde gerçekleştirilen bir dizi işlemi gruplayan ve bu işlemlerin tamamının başarılı bir şekilde tamamlanmasını veya hiçbirinin gerçekleştirilmemesini sağlayan bir yöntemdir. Transactionlar, veri bütünlüğünü korumak ve eşzamanlı işlemlerde çakışmaları çözmek için kullanılır.

LINQ ve Entity Framework ile Transactionlar Kullanarak Çakışmaların Çözülmesi

LINQ ve Entity Framework kullanarak, transactionlarla çakışmaları çözmek için aşağıdaki adımları takip edebiliriz:

  1. Veritabanı bağlantısı oluşturun.
  2. Transaction başlatın.
  3. Transactionları gerçekleştirin.
  4. Transactionı tamamlayın veya geri alın.

Örnek: Banka Hesaplarında Para Transferi

Bu örnekte, iki banka hesabı arasında para transferi gerçekleştiren bir uygulama için transactionlarla çakışmaların nasıl çözüleceğini göreceğiz.

Öncelikle, Entity Framework’te kullanılacak olan veritabanı nesnesini tanımlayalım:

public class BankDbContext : DbContext
{
    public DbSet<BankAccount> BankAccounts { get; set; }
}

public class BankAccount
{
    public int Id { get; set; }
    public string Owner { get; set; }
    public decimal Balance { get; set; }
}

Ardından, iki banka hesabı arasında para transferi gerçekleştiren bir işlemi yönetelim:

public void TransferFunds(int sourceAccountId, int targetAccountId, decimal amount)
{
    using (var context = new BankDbContext())
    {
        // İşlemi başlat
        using (var transaction = context.Database.BeginTransaction())
        {
            try
            {
                // Kaynak hesabı al
                var sourceAccount = context.BankAccounts.Find(sourceAccountId);
                if (sourceAccount == null)
                {
                    throw new InvalidOperationException("Kaynak hesap bulunamadı.");
                }

                // Hedef hesabı al
                var targetAccount = context.BankAccounts.Find(targetAccountId);
                if (targetAccount == null)
                {
                    throw new InvalidOperationException("Hedef hesap bulunamadı.");
                }

                // Para transferini gerçekleştir
               
                sourceAccount.Balance -= amount;
                targetAccount.Balance += amount;

                // Değişiklikleri kaydet
                context.SaveChanges();

                // İşlemi tamamla
                transaction.Commit();
            }
            catch (Exception ex)
            {
                // İşlemi geri al
                transaction.Rollback();
                throw new InvalidOperationException("Para transferi gerçekleştirilemedi.", ex);
            }
        }
    }
}

Bu örnekte, TransferFunds fonksiyonu, iki banka hesabı arasında para transferini gerçekleştirmek için bir transaction başlatır. İşlemin başarıyla tamamlanması durumunda, işlem Commit ile tamamlanır ve değişiklikler veritabanına kaydedilir. Eğer işlem sırasında bir hata oluşursa, transaction Rollback ile geri alınır ve veritabanındaki tutarlar önceki durumlarına döner.

Öneriler

Transactionlarla çakışmaları çözerken dikkate almanız gereken bazı noktalar şunlardır:

  1. Transactionları mümkün olduğunca kısa tutun: İşlem süresi ne kadar uzun olursa, eşzamanlı transactionlar arasındaki çakışma olasılığı o kadar artar. Transactionları kısa tutarak, veritabanı kaynaklarının daha verimli kullanılmasını sağlayabilirsiniz.

  2. Transactionlar sırasında hataları yönetin: Transactionlar sırasında meydana gelen hataların doğru şekilde yönetilmesi, veri bütünlüğünü korumak için önemlidir. Hataları işlem geri alınarak ve uygun hata mesajlarıyla yönetin.

  3. Transactionları gerekli durumlarda kullanın: Transactionlar, veri bütünlüğünü korumak için gereklidir, ancak her işlem için işlem kullanmak performansı olumsuz yönde etkileyebilir. Transactionları, birden fazla işlemin başarılı bir şekilde tamamlanmasını veya hiçbirinin gerçekleştirilmemesini sağlamak için gereken durumlarda kullanın.



Bu gibi daha fazla gönderi...

SemaphoreSlim Sınıfı: C#'ta Çoklu Görevlere Dayalı Programlama

2023-06-10 | #net #semaphoreslim

Genel Bakış SemaphoreSlim sınıfı, bir veya daha fazla threadin aynı anda belirli bir kaynağı veya işlemi kullanmasını kontrol etmek için C# ‘ta kullanılan bir yapıdır. SemaphoreSlim, aynı anda kaynağa erişebilecek thread sayısını sınırlar. SemaphoreSlim kullanımı, genellikle çok threadli uygulamalarda deadlock durumlarını önlemek ve belirli bir kaynağın aynı anda yalnızca bir veya daha fazla thread tarafından kullanılmasını sağlamak için kullanılır. SemaphoreSlim Kullanımı SemaphoreSlim sınıfı, aşağıdaki gibi kullanılır: SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1, 1); Burada ilk parametre, aynı anda kaç threadin kaynağı kullanabileceğini belirler.

Devamı 


Basit Bir Rest Api Client Geliştirelim 9

2023-05-14 | #diy-rest-api-client #do-it-yourself #net #rest-api

HTTP isteklerini izlemek ve teşhis etmek için daha fazla yetenek ekleyerek, kütüphanemizi daha da geliştirebiliriz. Bu amaçla, isteklerin ve yanıtların bazı temel bilgilerini loga kaydeden bir middleware ekleyelim. Bu özellik, HTTP isteklerinin ve yanıtlarının kaydını tutmak için HttpClient‘in DelegatingHandler sınıfını kullanır. Bu, bir HTTP isteği gönderildiğinde ve bir yanıt alındığında çalışan bir kod parçasıdır. Bu durumda, HTTP isteklerinin ve yanıtlarının bazı temel bilgilerini loga kaydeder. Aşağıda, bu özelliği eklemek için gereken kod parçacığı bulunmaktadır:

Devamı 


Basit Bir Rest Api Client Geliştirelim 8

2023-05-12 | #diy-rest-api-client #do-it-yourself #net #rest-api

Bu noktada, geliştirmemiz gereken bir diğer önemli konu da güvenlikle ilgili olabilir. Özellikle, API çağrıları genellikle belirli bir kimlik doğrulama yöntemi gerektirir. Bunu sağlamak için, HTTP istemcimizi çok kullanılan iki kimlik doğrulama yöntemiyle, yani Basic Authentication ve Bearer (Token) Authentication ile uyumlu hale getirebiliriz. Bu amaçla, istemcimize iki yeni metot ekleyelim: public void SetBasicAuthentication(string username, string password) { var basicAuthValue = Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}")); SetDefaultHeader("Authorization", $"Basic {basicAuthValue}"); } public void SetBearerToken(string token) { SetDefaultHeader("Authorization", $"Bearer {token}"); } Bu metodlar, Authorization başlığını ayarlar, böylece her HTTP talebi kimlik doğrulama bilgilerini içerir.

Devamı 