Ana içeriğe atla

ASP.NET MVC ile Entity Framework Kullanımı 3(Sum-Average-Top)

Merhaba Arkadaşlar,

ASP.NET MVC ile Entity Framework kullanımı yazılarımıza devam ediyoruz. Geçen yazılarımızda Select ve Insert işlemlerini tanıtmıştık kısaca. Bu yazımızda ise,Entity Framework ile daha profesyonel ve advanced select operasyonları üzerinde çalışmalar yapacağız.

Veritabanı üzerinde,iş biriminin istekleri basit select sorgusu ile olmayabiliyor. Bizden çekilen verilerin toplanması,ortalanmasının alınması ve ilk "x" kayıdın çekilmesini talep edebiliyorlar. Bu nedenle bu hafta Entity Framework ile Select operasyonlarında gruplama,sıralama ve top konularını inceleyeceğiz.


Entity Framework İle Sum Kullanımı

Bazen elde edilen verilerden toplam operasyonu gerekmektedir. Bu tarz durumlarda,SUM özelliğini kullanmaktayız. İlk etapta, GetTotalRate isminde integer değer geri veren bir fonksiyon oluşturduk. Daha sonrasında ise ToplamRate isimli değişkenimize EmployeePayHistories tablosunda Rate alanlarının toplam değerini hesaplatıp sonucu atadık. En sonrasında ise,ToplamRate isimli değişkenimizi geri döndürdük.


1
    2
    3
    4
    5
    6
    public int GetTotalRate ()
            {
                int ToplamRate = Convert.ToInt32(((from t in db.EmployeePayHistories select t.Rate).Sum()));
                return ToplamRate;
    
            }
    

Entity Framework ile Average Kullanımı


Average ise elde edilen değerlerin ortalamasını alan fonksiyondur. Bunun için aşağıdaki kodları inceleyebilirsiniz.Çalışma mantığı sum ile aynıdır.

1
    2
    3
    4
    5
   public int GetAverageRate()
            {
                int AverageRate = Convert.ToInt32(((from t in db.EmployeePayHistories select t.Rate).Average()));
                return AverageRate;
            }
    

Bu kod bloğu SQL Server üzerinde tam olarak aşağıdaki işlemi yapmaktadır.  Biz bu işlemi uygulama katmanı üzerinden yapmış olduk.



Entity Framework ile Top Kullanımı

Veriler ile işlem yaptığımız için zaman zaman tüm verileri select etmek istemeyiz. Çünkü tüm veriye ihtiyacımız olmayabilir ya da tüm veriyi çekmek fazla kaynak tüketebilir tablo boyutu nedeniyle.. Bu nedenle, top özelliğini kullanmaktayız. Tablodan ilk 100 kayıdı çekmek için yada ilk 1000. İstediğimiz sayıda en üstteki kayıdı çekebiliriz.  Kullanım örneğini aşağıda görebilirsiniz.



1
    2
    3
    4
    5
    6
    7
    8
        public ActionResult Index()
            {
    
                List<Employee> Top100Calisan = new List<Employee>();
                Top100Calisan = db.Employees.Take(100).ToList();
    
                return View(Top100Calisan);
            }
    


List<Employee> Top100Calisan = new List<Employee>();
Top100Calisan isminde bir Employee listesi oluşturulur.
Top100Calisan = db.Employees.Take(100).ToList();
Veritabanındaki Employees tablosundan Take(100) komutu ile ilk 100 kayıt çekilir.
return View(Top100Calisan);
Top100Calisan listesi view'a gönderilir.



Bu yazımızda Sum-Average-Top kullanımını inceledik. Sum ve Average MVC teknolojisinde LINQ kullanarak yapıldı. Top ise Entity Framework kullanarak yapılmıştır. Bunlar üzerine birkaç pratik yapmanızı tavsiye ederim.

Saygılarımla,
Görüşmek üzere.



Yorumlar

Bu blogdaki popüler yayınlar

ASP.NET Core ile Visual Studio Code Ortamında Web API Geliştirmek

Merhaba Arkadaşlar, Önceki yazılarımızda MVC ile Web Programlama üzerine çalışmalar yapmıştık. Bu yazımda herkesin aklında bir fikir ve önbilgi oluşturmak adına MVC yapısından farklı olarak Web API konusuna giriş yapacağız. MVC yazılarına bu hafta devam etmedik çünkü MVC'ye devam ettikçe bazı kavramlar ve işlemler API ile daha kolay çözülebileceğini fark edeceksiniz. Bunu fark etmeniz için araya hem bir Web API yazısı koymuş olduk hem de .NET Core 2.0 ve Visual Studio Code ortamlarını tanımış olduk. Herşeyi ezbere bilmek zorunda değiliz ama en azından bazı kavramlar aklımızda yer etmeli bir önbilgimiz olmalı. Uzmanlığımız dışında bile olsa farklı konularda az da olsa bilgimiz olmalı ve gerektiğinde kendimizi farklı bir alanda diğer kişilerden daha hızlı uzmanlık kazanacak konuma getirmeliyiz :) Benim yorumlarım bu şekilde. Konumuza başlayacak olursak .NET Core nedir kısaca özetlemek gerekecek. Microsoft’un öncelikle IIS üzerinde PHP dosyalarının çalıştırılabilmesi daha ...

Powershell ile Web Tarayıcı Cookie Temizliği

Web tarayıcıların ürettiği cookie ve minik boyuttaki veriler uzun bi süre temizlenmediği durumda yüksek boyutlara ulaşabilir ve bilgisayarımızın performansını kötü etkileyebilir. Bu tarz cookie temizliği ve yönetimi işlemlerinin periyodik olarak yapılması bilgisayarımızın performansı arttıracak ve disk alanı üzerinde bize bir miktarda olsa yer kazandıracaktır. Bu tarz işlemleri yapan programlar internette mevcut ancak bazılarının güvenilirliği tartışılır ve cookie temizliği işlemini periyodik olarak yapmıyor. Powershell ile arkaplan işlerini ve browser yönetimi özelliklerini kullanarak cookie yönetimini ve temizliğini periyodik olarak gerçekleştirmek mümkün. Bu sayede hem güvenlik konusunda hem de işlevsellik konusunda kullanıcı dostu bir modül yapmak mümkündür. Aşağıdaki powershell komutları browser üzerindeki cookie temizliği işlemini yapmaktadır. Not: Cookie Temizleme işlemini yapan fonksiyon aşağıdaki github projesinden alıntıdır. Bu scriptin üzerine birkaç ekl...

SQL Server Sorgu İyileştirme Çalışması

Performans Ölçüm Kriterleri Bu makale ile SQL Server üzerinde çalışan query'lerin optimize edilmesi için gerekli olan ilk aşama maddeleri ve çözümleri işlenmektedir. Veritabanı üzerinde koşan sorguların optimize edilmesi bu maddeler ile sınırlı olmayıp ayrı bir başlık altında incelenmektedir. Bu makale  konu hakkında sağlam bir temel ve ön fikir edinmek isteyenler için güzel bir kaynak olacaktır. SQL Server üzerinde çalışmakta olan bir sorgunun performans iyileştirme işlemleri için ilk etapta dikkat ve kontrol edilmesi gereken bazı maddeler vardır.  Performans Analizi Kontrol Maddeleri 1.       İlgili T-SQL çalıştırılmadan önce Time ve IO İstatistikleri ON Mode'a alınmalıdır. Bu istatistiklerin açılması ile çalışan T-SQL'in çalışma süresinin detayı(CPU ve Other Time) ve sorguda çalışan tablolar üzerindeki IO istatistiklerinin detayı tespit edilebilir duruma gelmektedir. SET STATISTICS TIME ON SET STATISTICS IO ON SELECT c....