LINQ Language Integrated Query

Slides:



Advertisements
Benzer bir sunumlar
Saatte V km hız ile giden bir aracın t zamanda aldığı yolu bulan metodu yazınız. Metodu kullanacak bir program yazınız. ( yol=hız*zaman, x=V*t) — Metot.
Advertisements

Fonksiyonlar.
VB.net ile SQL SERVER’a bağlanmak
Değişkenler ve bellek Değişkenler
LINQ { C# 3.0 ve Language Integrated Query }
BPR152 ALGORİTMA VE PROGRAMLAMA - II
Programlama-II (Java ile Bilgisayar Programlama)
Nesneye Dayalı Programlama
SQL Structured Query Language (Yapısal sorgulama dili)
dataReader- DataAdapter
Microsoft Danışman Öğrenci
Veri Yapıları ve Algoritmalar dönem
OOP UYGULAMA 5.
BPR152 ALGORİTMA VE PROGRAMLAMA - II
Görsel Programlama II Ders 6 Öğr.Gör. Mustafa KARABULUT.
EkoPC Bilişim Ltd. Eğitim Hizmetleri
Veritabanı Yönetim Sistemleri-I
PROGRAMLAMA DİLLERİNE GİRİŞ Ders 4: Diziler
Namespaces and .NET Class Library (İsim Alanları Sınıf Kütüphanesi)
PROGRAMLAMA DİLLERİNE GİRİŞ Ders 6: Sınıflar
Görsel Programlama II Ders 1 Öğr.Gör. Mustafa KARABULUT.
BPR152 ALGORİTMA VE PROGRAMLAMA - II
MVP (Microsoft Most Valuable Professional) Nedir? Microsoft’un En Değerli Profesyonelleri (MVP’ler) bir veya daha fazla sayıdaki Microsoft ürünü konusunda.
BPR152 ALGORİTMA VE PROGRAMLAMA - II
Diziler.
DİZİLER.
BPR152 ALGORİTMA VE PROGRAMLAMA - II
DELEGATE OOP-UYG.
Erişim Denetimi, Fonksiyon
C# Metot Overloading (Aşırı yükleme)
İSİM UZAYLARI (NAMESPACE)
C#.NET 5.0 C# .NET 5.0 Eğitimleri Volkan KANAT.
.Net teknolojisi ve C# Yasin Gedik Dokuz Eylül Üniversitesi (4. Sınıf) Microsoft Danışman Öğrenci
C#.NET 5.0 C# .NET 5.0 Eğitimleri Volkan KANAT.
LINQ (Language Integrated Query)
Görsel C# Programlama Güz 2009 (6. Hafta).
Java Sınıf ve Nesne Kavramı UML Gösterimi
Veritabanı İşlemleri.
Net Class Framework ’ ün en üst yapısına İsim Uzayı denir. İsim uzayları ; pascal programlama dilinde 1990 ve hatta öncesinden beri varolmuş, C’de yer.
MySQL Operatörleri ve Fonksiyonları
SQL SERVER 2008 Yücel YILDIRIM.
Chapter 6: Using Arrays.
Ders 2- Veri türleri, Karar ve Döngü Yapıları, Görsel Kontröller Aslı Ergün.
İSİM UZAYLARI.
Görsel Programlama II Ders 5 Öğr.Gör. Mustafa KARABULUT.
NESNEYE YÖNELİK PROGRAMLAMA
Kalıtım , Sınıf Asli Ergün.
SQL Komutları (2) Uzm. Murat YAZICI.
DÖNGÜLER.
JAVA’DA DİZİLER Dr.Galip AYDIN.
Ders İçeriği Liste Soyut veri yapısı (ADT)
LINQtoSQL Silverligth Uygulamalarında LinqtoSql. LINQ (Language Integrated Query) özellikle dil içerisinde, Sql tarzı sorgular yazabilmemizi ve bunları.
Bil 102 Bölüm 6 Diziler.
Bil 102 Bölüm 3 Java’da Program Akış Denetimi Bil 1021.
Bilgisayar programlarının en büyük avantajı, kullanıcının işini kolaylaştırmalarıdır. Her bilgisayar programı bunu değişik metotlar kullanarak sağlar.
Ders 2- Veri türleri, Karar ve Döngü Yapıları, Görsel Kontröller
Görsel C# ile Windows Programlama
SINIFLAR ve NESNELER. İlk sınıfımızı ekleyelim class KrediHesap { public ulong HesapNo; public double Limit; public string KartSahibi; }
SQL’ e Giriş Uzm. Murat YAZICI.
BİLGİSAYAR programlama II
LINQ { C# 3.0 ve Language Integrated Query } MEHMET MECİT GÖK NO:
İbrahim Olgaç PROGRAMLAMA DİLLERİ SUNUMU C#
LINQ { C# 3.0 ve Language Integrated Query } Uğur UMUTLUOĞLU.
ALGORİTMA VE PROGRAMLAMAYA GİRİŞ
© Marmara Üniversitesi Uzaktan Eğitim Uygulama ve Araştırma Merkezi
Basit Sorgulamalar Yapmak
VISUAL STUDIO İÇERİSİNDE VERİ TABANI BAĞLANTISI ACCESS DATA SOURCE SAVAŞ TUNÇER
VERİ TABANI VE VISUAL STUDIO SQL LOCAL DB(YEREL VERİ TABANINI SAYFAYA BAĞLAMA Savaş TUNÇER.
Asp.Net Veritabanı İşlemleri
JAVA’DA DİZİLER. Özet  Dizi: belirli sayıda ve aynı veri türünden de ğ işkenlere aynı adla erişilmesini sa ğ layan bir yapıdır.  Dizilerde döngü işlemleri.
Sunum transkripti:

LINQ Language Integrated Query Uğur UMUTLUOĞLU nedirtv?com INETA Speaker

Uğur UMUTLUOĞLU Netron Eğitmen & Danışman E-posta: ugur@nedirtv.com ugur.umutluoglu@netron.com.tr Web Site: www.umutluoglu.com

AJANDA LINQ’e Neden İhtiyaç Duyuldu LINQ’e Hazırlık: C# 3.0 ile Gelen Yenilikler LINQ (Language Integrated Query) LINQ to Object LINQ to XML LINQ to SQL C# 3.0 Yenilikleri LINQ’in Neresinde? Örnek Uygulamalar

LINQ’e Neden İhtiyaç Duyuldu Nesneler hakkında bilgilere kolay ulaşabilmek, nesneler üzerinde arama, sıralama, gruplama gibi işlemleri kolaylaştırma ihtiyacı Bu tip işlemleri, kullanılan dilden farklı ikinci bir bileşene(dile, yazılıma veya projeye eklenecek farklı katmanlara) ihtiyaç duymadan gerçekleştirebilme ihtiyacı

LINQ’e Neden İhtiyaç Duyuldu Veritabanındaki tabloları .NET nesnesi olarak uygulama içerisinde sorgulamak XML dosyalarındaki verileri XPath ve XQuery kullanmadan, SQL ifadesi yazar gibi sorgulamak Koleksiyon ve dizi nesnelerini sorgulamak Ve bu sorgulamaları dil ile entegre şekilde oluşturabilmek...

LINQ’e Hazırlık: C# 3.0 .NET Framework 3.5’teki en önemli yenilik LINQ’dir. Bu sürümde getirilen diğer tüm yenilikler LINQ için gerekli parçalardır ve LINQ projesinin daha tutarlı hale gelmesini sağlamıştır

Implicitly Typed Local Variables Standart tanımlama yolu int sayi = 25; string sehir = "İstanbul"; Customer musteri = new Customer("Bülent Sözge"); List<double> liste = new List<double>(); var kelimesi kullanılarak yapılan tanımlamalar var yeniSayi = 25; var yeniSehir = "İstanbul"; var yeniMusteri = new Customer("Bülent Sözge"); var yeniListe = new List<double>();

Object and Collection Initializers C# 2.0 Yazımı Personel p = new Personel(8, "Burak Batur", "Denizli"); List<string> oyuncular = new List<string>(); oyuncular.Add("Rüştü"); oyuncular.Add("Servet"); C# 3.0 Yazımı Personel p = new Personel() { Id = 8, Isim = "Burak Batur", DogumYeri = "Denizli" }; List<string> oyuncular = new List<string>() { “Rüştü", “Servet" };

Anonymous Types Önceden hazırlanmamış bir sınıfın derleme zamanında yapılan tanımlamaya göre otomatik olarak oluşmasına ve kullanılmasına izin verilmektedir var oyuncu = new { FormaNo = 14, Isim = "Arda", Mevki = "Orta Saha" }; Console.WriteLine(oyuncu.Isim);

Extension Methods Varolan tipe yeni bir metot eklenebilir Örneğin kendi yazdığımız bir metodun String sınıfının üyesi olması ve projedeki tüm String değişkenler üzerinden bu metodun çağrılması sağlanabilir

Extension Methods static class StringExtensions { public static string TersCevir(this string s) char[] cDizi = s.ToCharArray(); Array.Reverse(cDizi); return new string(cDizi); }

Lambda Expressions delegate int ToplamaDelegate(int sayi1, int sayi2); static void Main(string[] args) { ToplamaDelegate toplaTemsilci20 = delegate(int x, int y) return x + y; }; } C# 2.0’da anonymous method tanımlaması (İsimsiz bir metodun yazılması yeterlidir)

Lambda Expressions delegate int ToplamaDelegate(int sayi1, int sayi2); static void Main(string[] args) { ToplamaDelegate toplaTemsilci30 = (x, y) => x + y; } C# 3.0’da lambda expression tanımlaması (=> operatörünün işlemi işaretlemesi yeterlidir)

Query Expressions LINQ (Language Integrated Query - Dile entegre sorgu) T-SQL'de tablolara, Xquery’de Xml verilere yapılan sorguların benzeri artık uygulamadaki nesnelere de yapılabilir IEnumarable<T> arayüzünü uygulamış tüm nesneler LINQ ifadeleriyle sorgulanabilir IEnumarable<T> arayüzünü uygulamamış nesneler Extension Method’lar sayesinde sorgulanır hale getirilebilir

Query Expressions LINQ sorgularında Where, Select, OrderBy, Group By gibi kelimeler ve Count, Sum gibi gruplama fonksiyonları kullanılabilir Yazılan sorgu ifadeleri arka planda uygun metotlara çevrilir Anahtar kelimeler ve gruplama fonksiyonları SQL’deki anlamlarını taşırlar; fakat LINQ’deki söz dizimi biraz farklıdır

Query Expressions from sayi in sayiDizisi where sayi < 100 Sorguda kullanılacak değer from sayi in sayiDizisi where sayi < 100 select sayi Ele alınacak liste (dizi veya koleksiyon gibi) Seçilecek verileri belirleme (Şart bildirme, sıralama, gruplama) Sonuçta yer alacak değer int[] sayilar = new int[] { 3, 9, 6, 15, 4, 22 }; var ciftSayilar = from s in sayilar where s % 2 == 0 select s; foreach (int sayi in ciftSayilar) Console.WriteLine(sayi);

LINQ Mimarisi

LINQ to Objects IEnumarable<T> arayüzünü uygulamış tüm .NET tipleri LINQ ile sorgulanabilir Diziler (Array) Koleksiyonlar (Collections) Dizi veya Koleksiyon Üreten Tüm Metotlar Dosya ve Klasörler (System.IO vasıtasıyla) Dosya İçerikleri Tipler (Reflection vasıtasıyla)

LINQ to XML XPath ve XQuery sorgulama teknolojilerine alternatif olarak daha kolay sorgulama yapısı sunar XElement nesnesi üzerinden elde edilen XML düğümleri standart LINQ ifadeleriyle sorgulanabilir

LINQ to Data LINQ ile DataSet, DataTable nesneleri içerisinde saklanan veriler sorgulanabilir Veritabanındaki nesnelerin uygulama tarafındaki karşılıkları olan Entity sınıfları üzerinde LINQ sorguları yazılabilir Tablolar arasında ilişkilere izin verir ve ilişkisel LINQ sorguları yazılabilir Yapılan değişiklikler veritabanına yansıtılabilir

LINQ’den Önce SqlConnection con = new SqlConnection("data source=localhost; initial catalog=NorthWind; integrated security=true"); SqlDataAdapter da = new SqlDataAdapter("Select ProductID, ProductName, UnitPrice From Products Where CategoryID=@kategori_id", con); da.SelectCommand.Parameters.AddWithValue("@kategori_id", 5); DataTable dt = new DataTable(); da.Fill(dt); GridView1.DataSource = dt; GridView1.DataBind();

LINQ’den Sonra NorthwindDataContext northwind = new NorthwindDataContext(); GridView1.DataSource = from urun in northwind.Products where urun.CategoryID == 5 select new { urun.ProductID, urun.ProductName, urun.UnitPrice }; GridView1.DataBind();

C# 3.0 Yenilikleri LINQ’in Neresinde? var buyukJpgDosyalar = from dosya in dosyaListe where dosya.Extension == ".jpg“ && dosya.Length > 100000 select new { DosyaAdi = dosya.Name, Boyut = dosya.Length + "KB." }; Implicitly Typed Local Variables Anonymous Type Object Initializer

C# 3.0 Yenilikleri LINQ’in Neresinde? Kod derlendiğinde LINQ sorgusu arka planda uygun metotlara dönüştürülür Lambda Expressions Extension Methods

LINQ – Query Expressions

Mutlaka Göz Atın! 101 LINQ Örneği ADO.NET Entity Framework http://msdn.microsoft.com/en-us/vcsharp/aa336746.aspx ADO.NET Entity Framework Pro LINQ with C# 2008

Uğur UMUTLUOĞLU E-posta: ugur@nedirtv.com ugur.umutluoglu@netron.com.tr Web Site: www.umutluoglu.com

Teşekkürler... Soru - Cevap