Mavzu: linq texnologiyasi. Linq sintaksisi. Qidirish, tartiblash,guruhlash, tanlash operatorlari. So'rovlar. Qism so'rovlar. Proeksiyalash. Boshqa turga keltirish. Agregatsiya metodlari



Yüklə 11,76 Kb.
tarix19.05.2023
ölçüsü11,76 Kb.
#117682
Linq texnologiyas


Mavzu: LINQ texnologiyasi. LINQ sintaksisi. Qidirish, tartiblash,guruhlash, tanlash operatorlari. So'rovlar. Qism so'rovlar.Proeksiyalash. Boshqa turga keltirish. Agregatsiya metodlari.
Reja:
1. Kirish.
1.1. LINQ texnologiyasi;
1.2. LINQ sintaksisi;
2. Asosiy qism.
2.1.Ba’zi operatorlar(tanlash,guruhlash,tartiblash);
2.2.So’rovlar va ularning qismlari;
2.3. Agregatsiya metodlari;
3. Yakuniy qism.
3.1. Xulosa;
3.2. Foydalangan adabiyotlar;
LINQ (Language-Integrated Query) - bu ma'lumot manbasidan so’rov olish uchun oddiy va qulay til. Ma'lumotlar manbayi sifatida - IEnumerable interfeysini (masalan, standart to'plamlar, massivlar) amalga oshiradigan obyekt, DataSet, XML hujjati bo'lishi mumkin. Ammo manba turidan qat'iy nazar, LINQ ma'lumotni olish uchun barchasi uchun bir xil usulni qo'llashga imkon beradi.
Qisqacha qilib aytganda LINQ - kodni ixchamlashtirish va oson o'qish imkoniyatini beradi va undan turli xil ma'lumot manbalari uchun so'rovlarda foydalanish mumkin.
LINQ ning bir nechta turi mavjud:
LINQ to Objects : Massivlar va to'plamlar bilan ishlash uchun ishlatiladi
LINQ to Entities : Entity Framework texnologiyasi orqali ma'lumotlar bazalariga kirishda foydalaniladi
LINQ dan Sql : MS SQL Server-da ma'lumotlarga kirish texnologiyasi
LINQ to XML : XML fayllari bilan ishlashda ishlatiladi
LINQ to DataSet : DataSet obyekti bilan ishlashda foydalaniladi
Parallel LINQ (PLINQ) : parallel so'rovlarni bajarish uchun ishlatiladi
LINQ so'rovlari natijalarni obyekt sifatida qaytaradi. Bu sizga natijalar to'plamida obyektga yo'naltirilgan yondashuvni ishlatishga va natijalarning turli formatlarini obyektlarga aylantirish haqida tashvishlanmaslikka imkon beradi.
LINQ-ning afzalliklari
Tanish til: Ishlab chiquvchilar ma'lumotlar manbalarining har bir turi yoki ma'lumotlar formati uchun yangi so'rovlar tilini o'rganishlari shart emas.
Kamroq kod yozish: Bu an'anaviy yondoshuv bilan taqqoslaganda yoziladigan kod miqdorini ancha kamaytiradi.
Tushunarli kod: LINQ kodni yanada tushunarli qiladi, shuning uchun boshqa ishlab chiquvchilar uni osonlikcha tushunishlari va saqlab turishlari mumkin.
Bir nechta ma'lumot manbalarini so'rov qilishning standartlashtirilgan usuli: Bir xil ma'lumot manbalariga so'rov yozish uchun bir xil LINQ sintaksisidan foydalanish mumkin.
So'rovlarning vaqt xavfsizligini kompilyatsiya qilish: kompilyatsiya vaqtida obyektlarning turini tekshirishni ta'minlaydi.
IntelliSense-ni qo'llab-quvvatlash: LINQ umumiy to'plamlar uchun IntelliSense-ni taqdim etadi.
Ma'lumotlarni shakllantirish: Siz har xil shakldagi ma'lumotlarni olishingiz mumkin.
LINQ dan foydalanish
LINQ dan foydalanish uchun bizga .Net Framework 3.5 va C# 3.0 kerak bo’ladi(foydalanish uchun minimum versiyalar).
System kutubxonasiga qo’shimcha ravishda System.Linq kutubxonasidan foydalanamiz.

Misol:
using System;


using System.Linq;
namespace LINQ_operations
{
class Program
{
static void Main(string[] args)
{
// Ma’lumotlar manbayi (massiv)
string[] names = { "Bill", "Steve", "James", "Mohan" };
// LINQ so’rovi
var myLinqQuery = from name in names
where name.Contains('a')
select name;
// So’rovni ishlatish
foreach (var name in myLinqQuery)
Console.WriteLine(name + " ");
Console.ReadKey();
//some comment
}
}
}
Natija:

Amaldagi LINQ metodlari ro'yxati


Select : tanlangan qiymatlarning proektsiyasini belgilaydi
Where : tanlov filtrini belgilaydi
OrderBy : elementlarni o'sish tartibida tartiblaydi
OrderByDescending : elementlarni kamayish tartibida tartiblaydi
ThenBy : elementlarni o'sish tartibida tartiblash uchun qo'shimcha shartlarni belgilaydi
ThenByDescending : elementlarni kamayish tartibida tartiblash uchun qo'shimcha shartlarni belgilaydi
Join : ma'lum bir shart asosida ikkita to'plamni birlashtiradi
GroupBy : elementlarni kalitlarga ko'ra guruhlaydi
ToLookup : barcha elementlarni lug'atga qo'shgan holda elementlarni kalitlarga ko'ra guruhlaydi
GroupJoin : elementlarning ikkala to'plamini va kalitlarga ko'ra guruhlanishini amalga oshiradi
Reverse : elementlarni teskari tartibda tartiblaydi
All : to'plamdagi barcha elementlarning ma'lum bir shartga javob berishini aniqlaydi
Any : to'plamdagi kamida bitta elementning ma'lum bir shartga javob berishini aniqlaydi
Contains : to'plamda ma'lum bir element mavjudligini aniqlaydi
Distinct : to'plamdagi nusxalarni(bir xil elementlarni) olib tashlaydi
Except : ikkita to'plamning farqini, ya'ni faqat bitta to'plamda mavjud elementlarni qaytaradi
Union : ikkita bir xil to'plamlarni birlashtiradi
Intersect : ikki to'plamning kesishmasini, ya'ni ikkala to'plamda ham bo'lgan elementlarning kesishmasini qaytaradi
Count : to'plamdagi ma'lum bir shartga javob beradigan elementlar sonini hisoblaydi
Sum : to'plamdagi sonli qiymatlar yig'indisini hisoblaydi
Average : to'plamdagi sonli qiymatlarning o'rtacha qiymatini hisoblaydi
Min : minimal qiymatni topadi
Max : maksimal qiymatni topadi
Take : ma'lum miqdordagi elementlarni tanlaydi
Skip : ma'lum miqdordagi elementlarni o'tkazib yuboradi
TakeWhile : agar shart to'g'ri bo'lsa, ketma-ketlik elementlari zanjirini qaytaradi.
Aggregate usuli ko'rsatilgan ifodaga qarab to'plam elementlarini umumiy yig'ishni amalga oshiradi. Misol uchun:

int[] raqamlari = { 1, 2, 3, 4, 5};


int so'rovi = sonlar.Aggregate((x,y)=> x - y);

Console WriteLine (so'rov); // - o'n uch

So'rov o'zgaruvchisi massivni yig'ish natijasini ifodalaydi. Ifoda yig'ish sharti sifatida ishlatiladi (x,y)=> x - y, ya'ni birinchi elementdan ikkinchi element ayiriladi, keyin uchinchi element natijaviy qiymatdan chiqariladi va hokazo. Ya'ni, bu ifodaga teng bo'ladi:

int so'rovi = 1 - 2 - 3 - 4 - 5


Usulning yana bir versiyasi jamlama operatsiyalar zanjiri boshlanadigan boshlang'ich qiymatni o'rnatishga imkon beradi:

string[] so'zlar = { "Gaudeamus", "igitur", "Juvenes", "dum", "sumus" };


var gap = words.Aggregate("Matn:", (birinchi, keyingi) => $"{birinchi} {keyingi}");
Console WriteLine(jumla); // Matn: Gaudeamus igitur Juvenes dum sumus
Bunda massiv so'zlarining barcha elementlari birlashtiriladi, lekin yig'ish operatsiyasining birinchi elementi "Matn:" qatori bo'ladi.
Yüklə 11,76 Kb.

Dostları ilə paylaş:




Verilənlər bazası müəlliflik hüququ ilə müdafiə olunur ©azkurs.org 2025
rəhbərliyinə müraciət

gir | qeydiyyatdan keç
    Ana səhifə


yükləyin