LINQ - คู่มือฉบับย่อ
นักพัฒนาทั่วโลกมักประสบปัญหาในการสืบค้นข้อมูลเนื่องจากไม่มีเส้นทางที่กำหนดไว้และจำเป็นต้องใช้เทคโนโลยีหลายอย่างเช่น SQL, Web Services, XQuery เป็นต้น
แนะนำใน Visual Studio 2008 และออกแบบโดย Anders Hejlsberg LINQ (Language Integrated Query) ช่วยให้สามารถเขียนแบบสอบถามได้โดยที่ไม่มีความรู้เกี่ยวกับภาษาแบบสอบถามเช่น SQL, XML เป็นต้นการสืบค้น LINQ สามารถเขียนได้สำหรับประเภทข้อมูลที่หลากหลาย
ตัวอย่างแบบสอบถาม LINQ
ค#
using System;
using System.Linq;
class Program {
static void Main() {
string[] words = {"hello", "wonderful", "LINQ", "beautiful", "world"};
//Get only short words
var shortWords = from word in words where word.Length <= 5 select word;
//Print each word out
foreach (var word in shortWords) {
Console.WriteLine(word);
}
Console.ReadLine();
}
}
VB
Module Module1
Sub Main()
Dim words As String() = {"hello", "wonderful", "LINQ", "beautiful", "world"}
' Get only short words
Dim shortWords = From word In words _ Where word.Length <= 5 _ Select word
' Print each word out.
For Each word In shortWords
Console.WriteLine(word)
Next
Console.ReadLine()
End Sub
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
hello
LINQ
world
ไวยากรณ์ของ LINQ
มีไวยากรณ์สองแบบของ LINQ ดังต่อไปนี้
Lamda (วิธีการ) ไวยากรณ์
var longWords = words.Where( w ⇒ w.length > 10);
Dim longWords = words.Where(Function(w) w.length > 10)
คิวรี (ความเข้าใจ) ไวยากรณ์
var longwords = from w in words where w.length > 10;
Dim longwords = from w in words where w.length > 10
ประเภทของ LINQ
ประเภทของ LINQ มีการกล่าวถึงโดยสังเขปด้านล่าง
- LINQ เป็น Objects
- LINQ เป็น XML (XLINQ)
- LINQ เป็น DataSet
- LINQ เป็น SQL (DLINQ)
- LINQ ถึงเอนทิตี
นอกเหนือจากข้างต้นแล้วยังมีประเภท LINQ ชื่อ PLINQ ซึ่งเป็น LINQ แบบขนานของ Microsoft
LINQ Architecture ใน. NET
LINQ มีสถาปัตยกรรม 3 ชั้นซึ่งชั้นบนสุดประกอบด้วยส่วนขยายของภาษาและชั้นล่างสุดประกอบด้วยแหล่งข้อมูลที่โดยทั่วไปเป็นวัตถุที่ใช้อินเทอร์เฟซทั่วไปของ IEnumerable <T> หรือ IQueryable <T> สถาปัตยกรรมดังแสดงด้านล่าง
นิพจน์การค้นหา
นิพจน์แบบสอบถามไม่ใช่อะไรนอกจากแบบสอบถาม LINQ ซึ่งแสดงในรูปแบบที่คล้ายกับ SQL ที่มีตัวดำเนินการแบบสอบถามเช่น Select, Where และ OrderBy นิพจน์การค้นหามักเริ่มต้นด้วยคำหลัก "จาก"
ในการเข้าถึงตัวดำเนินการเคียวรี LINQ มาตรฐานควรนำเข้า namespace System.Query ตามค่าเริ่มต้น นิพจน์เหล่านี้เขียนขึ้นภายในไวยากรณ์แบบสอบถามที่เปิดเผยซึ่งเป็น C # 3.0
ด้านล่างนี้เป็นตัวอย่างเพื่อแสดงการดำเนินการแบบสอบถามที่สมบูรณ์ซึ่งประกอบด้วยการสร้างแหล่งข้อมูลการกำหนดนิพจน์แบบสอบถามและการดำเนินการสืบค้น
ค#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Operators {
class LINQQueryExpressions {
static void Main() {
// Specify the data source.
int[] scores = new int[] { 97, 92, 81, 60 };
// Define the query expression.
IEnumerable<int> scoreQuery = from score in scores where score > 80 select score;
// Execute the query.
foreach (int i in scoreQuery) {
Console.Write(i + " ");
}
Console.ReadLine();
}
}
}
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
97 92 81
วิธีการขยาย
แนะนำด้วย. NET 3.5 วิธีการส่วนขยายจะประกาศในคลาสแบบคงที่เท่านั้นและอนุญาตให้รวมวิธีการที่กำหนดเองเข้ากับอ็อบเจ็กต์เพื่อดำเนินการเคียวรีที่แม่นยำเพื่อขยายคลาสโดยไม่ต้องเป็นสมาชิกจริงของคลาสนั้น สิ่งเหล่านี้สามารถบรรทุกได้มากเกินไป
โดยสรุปเมธอดส่วนขยายใช้ในการแปลนิพจน์เคียวรีเป็นการเรียกเมธอดแบบเดิม (เชิงวัตถุ)
ความแตกต่างระหว่าง LINQ และ Stored Procedure
มีอาร์เรย์ของความแตกต่างระหว่างขั้นตอน LINQ และ Stored ความแตกต่างเหล่านี้กล่าวถึงด้านล่าง
โพรซีเดอร์ที่จัดเก็บนั้นเร็วกว่าคิวรี LINQ มากเนื่องจากเป็นไปตามแผนการดำเนินการที่คาดไว้
เป็นเรื่องง่ายที่จะหลีกเลี่ยงข้อผิดพลาดขณะดำเนินการค้นหา LINQ มากกว่าเมื่อเปรียบเทียบกับกระบวนงานที่เก็บไว้เนื่องจากก่อนหน้านี้มีการสนับสนุน Intellisense ของ Visual Studio รวมถึงการตรวจสอบแบบเต็มในระหว่างเวลาคอมไพล์
LINQ อนุญาตให้มีการดีบักโดยใช้.
LINQ ให้การสนับสนุนสำหรับฐานข้อมูลหลาย ๆ ฐานข้อมูลในทางตรงกันข้ามกับขั้นตอนการจัดเก็บซึ่งจำเป็นอย่างยิ่งที่จะต้องเขียนโค้ดซ้ำสำหรับฐานข้อมูลประเภทต่างๆ
การปรับใช้โซลูชันที่ใช้ LINQ นั้นง่ายและสะดวกเมื่อเทียบกับการปรับใช้ชุดของกระบวนงานที่เก็บไว้
ต้องการ LINQ
ก่อนหน้า LINQ จำเป็นอย่างยิ่งที่จะต้องเรียนรู้ C #, SQL และ API ต่างๆที่รวมทั้งสองอย่างเข้าด้วยกันเพื่อสร้างแอปพลิเคชันที่สมบูรณ์ เนื่องจากแหล่งข้อมูลและภาษาโปรแกรมเหล่านี้มีความต้านทานไม่ตรงกัน รู้สึกว่าต้องการการเข้ารหัสสั้น ๆ
ด้านล่างนี้คือตัวอย่างจำนวนเทคนิคที่หลากหลายที่นักพัฒนาใช้ในขณะที่ค้นหาข้อมูลก่อนการกำเนิดของ LINQ
SqlConnection sqlConnection = new SqlConnection(connectString);
SqlConnection.Open();
System.Data.SqlClient.SqlCommand sqlCommand = new SqlCommand();
sqlCommand.Connection = sqlConnection;
sqlCommand.CommandText = "Select * from Customer";
return sqlCommand.ExecuteReader (CommandBehavior.CloseConnection)
สิ่งที่น่าสนใจคือจากบรรทัดโค้ดที่โดดเด่นแบบสอบถามจะถูกกำหนดโดยสองรายการสุดท้ายเท่านั้น เมื่อใช้ LINQ แบบสอบถามข้อมูลเดียวกันสามารถเขียนในรูปแบบรหัสสีที่อ่านได้เช่นเดียวกับข้อความต่อไปนี้ที่กล่าวถึงด้านล่างซึ่งใช้เวลาน้อยลงมาก
Northwind db = new Northwind(@"C:\Data\Northwnd.mdf");
var query = from c in db.Customers select c;
ข้อดีของ LINQ
LINQ มีข้อดีมากมายและสิ่งที่สำคัญที่สุดคือการแสดงออกที่ทรงพลังซึ่งช่วยให้นักพัฒนาสามารถแสดงออกอย่างเปิดเผย ข้อดีอื่น ๆ ของ LINQ มีดังต่อไปนี้
LINQ นำเสนอการเน้นไวยากรณ์ที่พิสูจน์ว่ามีประโยชน์ในการค้นหาข้อผิดพลาดในช่วงเวลาออกแบบ
LINQ นำเสนอ IntelliSense ซึ่งหมายถึงการเขียนแบบสอบถามที่แม่นยำยิ่งขึ้นได้อย่างง่ายดาย
การเขียนโค้ดค่อนข้างเร็วใน LINQ และทำให้เวลาในการพัฒนาลดลงอย่างมาก
LINQ ทำให้การดีบักเป็นเรื่องง่ายเนื่องจากการรวมเข้ากับภาษา C #
การดูความสัมพันธ์ระหว่างสองตารางเป็นเรื่องง่ายด้วย LINQ เนื่องจากมีคุณสมบัติตามลำดับชั้นและช่วยให้การเขียนแบบสอบถามเข้าร่วมหลายตารางในเวลาน้อยลง
LINQ อนุญาตให้ใช้ไวยากรณ์ LINQ เดียวในขณะที่ค้นหาแหล่งข้อมูลที่หลากหลายและส่วนใหญ่เป็นเพราะรากฐานที่ไม่ซ้ำกัน
LINQ สามารถขยายได้ซึ่งหมายความว่าสามารถใช้ความรู้เกี่ยวกับ LINQ เพื่อสืบค้นแหล่งข้อมูลประเภทใหม่ได้
LINQ นำเสนอสิ่งอำนวยความสะดวกในการเข้าร่วมแหล่งข้อมูลหลายรายการในแบบสอบถามเดียวรวมทั้งแยกปัญหาที่ซับซ้อนออกเป็นชุดของการสืบค้นสั้น ๆ ที่ง่ายต่อการดีบัก
LINQ นำเสนอการแปลงที่ง่ายดายสำหรับการแปลงประเภทข้อมูลหนึ่งไปยังอีกประเภทหนึ่งเช่นการแปลงข้อมูล SQL เป็นข้อมูล XML
ก่อนที่จะเริ่มต้นด้วยโปรแกรม LINQ ควรทำความเข้าใจเกี่ยวกับความแตกต่างของการตั้งค่าสภาพแวดล้อม LINQ ก่อน LINQ ต้องการเฟรมเวิร์ก. NET ซึ่งเป็นแพลตฟอร์มที่ปฏิวัติวงการเพื่อให้มีแอพพลิเคชั่นที่หลากหลาย แบบสอบถาม LINQ สามารถเขียนใน C # หรือ Visual Basic ได้อย่างสะดวก
Microsoft นำเสนอเครื่องมือสำหรับทั้งสองภาษานี้ ได้แก่ C # และ Visual Basic โดยใช้ Visual Studio ตัวอย่างของเรารวบรวมและเขียนใน Visual Studio 2010 ทั้งหมดอย่างไรก็ตาม Visual Basic 2013 edition ยังมีให้ใช้งาน เป็นเวอร์ชันล่าสุดและมีความคล้ายคลึงกับ Visual Studio 2012 มาก
การติดตั้ง Visual Studio 2010 บน Windows 7
Visual Studio สามารถติดตั้งได้จากสื่อการติดตั้งเช่นดีวีดี ข้อมูลประจำตัวของผู้ดูแลระบบจำเป็นต้องติดตั้ง Visual Basic 2010 บนระบบของคุณให้สำเร็จ จำเป็นอย่างยิ่งที่จะต้องปลดการเชื่อมต่อ USB แบบถอดได้ทั้งหมดออกจากระบบก่อนการติดตั้งมิฉะนั้นการติดตั้งอาจล้มเหลว ข้อกำหนดฮาร์ดแวร์บางอย่างที่จำเป็นสำหรับการติดตั้งมีดังต่อไปนี้
ข้อกำหนดฮาร์ดแวร์
- 1.6 GHz ขึ้นไป
- แรม 1 GB
- 3 GB (เนื้อที่ว่างบนฮาร์ดดิสก์)
- ฮาร์ดดิสก์ไดรฟ์ 5400 RPM
- การ์ดแสดงผลที่รองรับ DirectX 9
- ไดรฟ์ดีวีดีรอม
ขั้นตอนการติดตั้ง
Step 1 - ขั้นแรกหลังจากใส่ดีวีดีด้วย Visual Studio 2010 Package แล้วให้คลิกที่ Install or run program from your media ปรากฏในกล่องป๊อปอัปบนหน้าจอ
Step 2- ตอนนี้การตั้งค่าสำหรับ Visual Studio จะปรากฏบนหน้าจอ เลือกInstall Microsoft Visual Studio 2010.
Step 3- ทันทีที่คุณคลิกกระบวนการจะเริ่มต้นและหน้าต่างการตั้งค่าจะปรากฏบนหน้าจอของคุณ หลังจากเสร็จสิ้นการโหลดส่วนประกอบการติดตั้งซึ่งจะใช้เวลาสักครู่ให้คลิกที่Next เพื่อไปยังขั้นตอนถัดไป
Step 4 - นี่เป็นขั้นตอนสุดท้ายของการติดตั้งและหน้าเริ่มต้นจะปรากฏขึ้นซึ่งเพียงเลือก "ฉันได้อ่านและยอมรับเงื่อนไขใบอนุญาตแล้ว" แล้วคลิกที่ Next ปุ่ม.
Step 5- ตอนนี้เลือกคุณสมบัติที่จะติดตั้งจากหน้าตัวเลือกที่ปรากฏบนหน้าจอของคุณ คุณสามารถเลือกFull หรือ Customตัวเลือก หากคุณมีเนื้อที่ดิสก์น้อยกว่าที่กำหนดซึ่งแสดงในข้อกำหนดพื้นที่ดิสก์ให้ไปที่กำหนดเอง
Step 6- เมื่อคุณเลือกตัวเลือกกำหนดเองหน้าต่างต่อไปนี้จะปรากฏขึ้น เลือกคุณสมบัติที่คุณต้องการติดตั้งแล้วคลิกUpdate หรือไปที่ขั้นตอนที่ 7 อย่างไรก็ตามขอแนะนำว่าอย่าใช้ตัวเลือกที่กำหนดเองเนื่องจากในอนาคตคุณอาจต้องใช้คุณสมบัติที่คุณเลือกไม่มี
Step 7- ในไม่ช้าหน้าต่างป๊อปอัปจะปรากฏขึ้นและการติดตั้งจะเริ่มขึ้นซึ่งอาจใช้เวลานาน จำไว้ว่านี่คือการติดตั้งส่วนประกอบทั้งหมด
Step 8- สุดท้ายคุณจะสามารถดูข้อความในหน้าต่างว่าการติดตั้งเสร็จสมบูรณ์แล้ว คลิกFinish.
การเขียนโปรแกรม C # โดยใช้ LINQ ใน Visual Studio 2010
เริ่ม Visual Studio 2010 Ultimate edition และเลือก File ตามด้วย New Project จากเมนู
กล่องโต้ตอบโครงการใหม่จะปรากฏขึ้นบนหน้าจอของคุณ
ตอนนี้เลือก Visual C # เป็นหมวดหมู่ภายใต้เทมเพลตที่ติดตั้งและจากนั้นเลือกเทมเพลต Console Application ดังแสดงในรูปด้านล่าง
ตั้งชื่อโครงการของคุณในช่องชื่อด้านล่างแล้วกดตกลง
โครงการใหม่จะปรากฏใน Solution Explorer ทางด้านขวามือของกล่องโต้ตอบใหม่บนหน้าจอของคุณ
ตอนนี้เลือก Program.cs จาก Solution Explorer และคุณสามารถดูรหัสในหน้าต่างตัวแก้ไขซึ่งขึ้นต้นด้วย 'การใช้ระบบ'
คุณสามารถเริ่มเขียนโค้ดโปรแกรม C # ต่อไปนี้ได้ที่นี่
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace HelloWorld {
class Program {
static void Main(string[] args) {
Console.WriteLine("Hello World")
Console.ReadKey();
}
}
}
กด F5 และเรียกใช้โครงการของคุณ ขอแนะนำอย่างยิ่งให้บันทึกโครงการโดยเลือกFile → Save All ก่อนดำเนินโครงการ
การเขียนโปรแกรม VB โดยใช้ LINQ ใน Visual Studio 2010
เริ่ม Visual Studio 2010 Ultimate edition และเลือก File ตามด้วย New Project จากเมนู
กล่องโต้ตอบโครงการใหม่จะปรากฏขึ้นบนหน้าจอของคุณ
ตอนนี้เลือก Visual Basic เป็นหมวดหมู่ภายใต้เทมเพลตที่ติดตั้งและจากนั้นเลือก Console Application template
ตั้งชื่อโครงการของคุณในช่องชื่อด้านล่างแล้วกดตกลง
คุณจะได้หน้าจอพร้อม Module1.vb เริ่มเขียนรหัส VB ของคุณที่นี่โดยใช้ LINQ
Module Module1
Sub Main()
Console.WriteLine("Hello World")
Console.ReadLine()
End Sub
End Module
กด F5 และเรียกใช้โครงการของคุณ ขอแนะนำอย่างยิ่งให้บันทึกโครงการโดยเลือกFile → Save All ก่อนดำเนินโครงการ
เมื่อโค้ดด้านบนของ C # หรือ VB ถูก cimpiled และรันจะให้ผลลัพธ์ดังนี้ -
Hello World
ชุดของวิธีการขยายที่สร้างรูปแบบแบบสอบถามเรียกว่า LINQ Standard Query Operators ในฐานะหน่วยการสร้างของนิพจน์การสืบค้น LINQ ตัวดำเนินการเหล่านี้มีความสามารถในการสืบค้นที่หลากหลายเช่นการกรองการเรียงลำดับการฉายภาพการรวม ฯลฯ
ตัวดำเนินการแบบสอบถามมาตรฐาน LINQ สามารถแบ่งออกเป็นตัวดำเนินการดังต่อไปนี้ตามฟังก์ชันการทำงาน
- ตัวดำเนินการกรอง
- เข้าร่วม Operators
- การดำเนินการฉาย
- ตัวดำเนินการเรียงลำดับ
- การจัดกลุ่มตัวดำเนินการ
- Conversions
- Concatenation
- Aggregation
- การดำเนินการของ Quantifier
- การทำงานของพาร์ติชัน
- การดำเนินงานรุ่น
- ตั้งค่าการทำงาน
- Equality
- ตัวดำเนินการองค์ประกอบ
ตัวดำเนินการกรอง
การกรองเป็นการดำเนินการเพื่อ จำกัด ชุดผลลัพธ์เพื่อให้มีองค์ประกอบที่เลือกเท่านั้นที่ตรงตามเงื่อนไขเฉพาะ
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
ที่ไหน | กรองค่าตามฟังก์ชันเพรดิเคต | ที่ไหน | ที่ไหน |
OfType | กรองค่าตามความสามารถในการเป็นประเภทที่ระบุ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
เข้าร่วม Operators
การเข้าร่วมหมายถึงการดำเนินการที่มีการกำหนดเป้าหมายแหล่งข้อมูลที่มีความสัมพันธ์ที่ยากต่อการติดตามซึ่งกันและกันในทางตรง
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
เข้าร่วม | ตัวดำเนินการเข้าร่วมสองลำดับบนพื้นฐานของคีย์ที่ตรงกัน | เข้าร่วม…ใน…บน…เท่ากับ… | จาก x In …, y In …โดยที่ xa = ya |
GroupJoin | เข้าร่วมสองลำดับและจัดกลุ่มองค์ประกอบที่ตรงกัน | เข้าร่วม…ใน…บน…เท่ากับ…เข้า… | เข้าร่วมกลุ่ม ... ใน ... บน ... |
การดำเนินการฉาย
การฉายภาพเป็นการดำเนินการที่วัตถุถูกเปลี่ยนเป็นรูปแบบใหม่โดยมีคุณสมบัติเฉพาะเท่านั้น
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
เลือก | ตัวดำเนินการจะแสดงค่าบนพื้นฐานของฟังก์ชันการแปลง | เลือก | เลือก |
SelectMany | ตัวดำเนินการจะแสดงลำดับของค่าซึ่งขึ้นอยู่กับฟังก์ชันการแปลงและทำให้แบนเป็นลำดับเดียว | ใช้หลายจากอนุประโยค | ใช้คำสั่ง From หลาย ๆ |
ตัวดำเนินการเรียงลำดับ
การดำเนินการเรียงลำดับอนุญาตให้จัดลำดับองค์ประกอบของลำดับบนพื้นฐานของแอตทริบิวต์เดียวหรือมากกว่า
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
สั่งโดย | ตัวดำเนินการจัดเรียงค่าตามลำดับจากน้อยไปมาก | สั่งโดย | สั่งโดย |
OrderByDescending | ตัวดำเนินการจัดเรียงค่าตามลำดับจากมากไปหาน้อย | ตามลำดับ ... | เรียงตาม ... จากมากไปน้อย |
โดย | ดำเนินการเรียงลำดับรองตามลำดับจากน้อยไปหามาก | สั่งโดย …, … | สั่งโดย …, … |
ThenByDescending | ดำเนินการจัดเรียงรองตามลำดับจากมากไปหาน้อย | ตามลำดับ…, …จากมากไปน้อย | เรียงลำดับตาม…, …จากมากไปน้อย |
ย้อนกลับ | ดำเนินการกลับลำดับขององค์ประกอบในคอลเลกชัน | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
การจัดกลุ่มตัวดำเนินการ
ตัวดำเนินการใส่ข้อมูลลงในบางกลุ่มตามแอตทริบิวต์ที่ใช้ร่วมกันทั่วไป
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
GroupBy | จัดระเบียบลำดับของรายการในกลุ่มและส่งคืนเป็นคอลเล็กชันประเภท IGrouping <key, element> ที่ไม่สามารถคำนวณได้ | กลุ่ม…ตาม - หรือ - กลุ่ม…โดย…เป็น… | กลุ่ม…โดย…เป็น… |
ToLookup | เรียกใช้การดำเนินการจัดกลุ่มซึ่งจะส่งคืนลำดับของคู่คีย์ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
Conversion
ตัวดำเนินการเปลี่ยนประเภทของออบเจ็กต์อินพุตและใช้ในแอพพลิเคชั่นที่หลากหลาย
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
AsEnumerable | ส่งคืนอินพุตที่พิมพ์เป็น IEnumerable <T> | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
AsQueryable | A (ทั่วไป) IEnumerable ถูกแปลงเป็น (ทั่วไป) IQueryable | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
นักแสดง | ดำเนินการแคสต์องค์ประกอบของคอลเล็กชันเป็นชนิดที่ระบุ | ใช้ตัวแปรช่วงที่พิมพ์อย่างชัดเจน เช่น: จากสตริง str ในคำ | จาก…เป็น… |
OfType | ค่าฟิลเตอร์โดยขึ้นอยู่กับความสามารถในการแคสเป็นประเภทเฉพาะ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ToArray | บังคับให้ดำเนินการสืบค้นและทำการแปลงคอลเลกชันเป็นอาร์เรย์ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ToDictionary | บนพื้นฐานของฟังก์ชันตัวเลือกคีย์กำหนดองค์ประกอบลงในพจนานุกรม <TKey, TValue> และบังคับให้ดำเนินการสืบค้น LINQ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ToList | บังคับให้เรียกใช้แบบสอบถามโดยการแปลงคอลเลกชันเป็นรายการ <T> | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ToLookup | บังคับให้ดำเนินการสืบค้นและใส่องค์ประกอบลงใน Lookup <TKey, TElement> โดยใช้ฟังก์ชันตัวเลือกคีย์ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
การเชื่อมต่อ
ดำเนินการต่อกันของสองลำดับและค่อนข้างคล้ายกับตัวดำเนินการ Union ในแง่ของการดำเนินการยกเว้นข้อเท็จจริงที่ว่าสิ่งนี้ไม่ได้ลบรายการที่ซ้ำกัน
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
Concat | ลำดับสองลำดับเชื่อมต่อกันสำหรับการก่อตัวของลำดับเดียว | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
การรวม
ดำเนินการรวมประเภทที่ต้องการและอนุญาตให้สร้างการรวมแบบกำหนดเองใน LINQ
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
รวม | ดำเนินการกับค่าของคอลเล็กชันเพื่อดำเนินการรวมแบบกำหนดเอง | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
เฉลี่ย | คำนวณค่าเฉลี่ยของคอลเล็กชันค่า | ไม่สามารถใช้ได้ | รวม ... ใน ... เป็นค่าเฉลี่ย () |
นับ | นับองค์ประกอบที่ตรงตามฟังก์ชันเพรดิเคตภายในคอลเลกชัน | ไม่สามารถใช้ได้ | รวม ... ใน ... นับ () |
LonCount | นับองค์ประกอบที่ตรงตามฟังก์ชันเพรดิเคตภายในคอลเลคชันขนาดใหญ่ | ไม่สามารถใช้ได้ | รวม ... ใน ... เป็น LongCount () |
สูงสุด | หาค่าสูงสุดภายในคอลเลกชัน | ไม่สามารถใช้ได้ | รวม ... ใน ... เป็น Max () |
นาที | ค้นหามูลค่าขั้นต่ำที่มีอยู่ในคอลเลกชัน | ไม่สามารถใช้ได้ | รวม ... ใน ... เป็นนาที () |
ผลรวม | ค้นหาผลรวมของค่าภายในคอลเล็กชัน | ไม่สามารถใช้ได้ | รวม ... ใน ... ผลรวม () |
การดำเนินการของ Quantifier
ตัวดำเนินการเหล่านี้ส่งคืนค่าบูลีนเช่น True หรือ False เมื่อองค์ประกอบบางส่วนหรือทั้งหมดภายในลำดับตรงตามเงื่อนไขที่ระบุ
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
ทั้งหมด | ส่งคืนค่า 'True' หากองค์ประกอบทั้งหมดของลำดับตรงตามเงื่อนไขเพรดิเคต | ไม่สามารถใช้ได้ | รวม…ใน…รวมทั้งหมด (…) |
ๆ | กำหนดโดยการค้นหาลำดับว่าองค์ประกอบใด ๆ ที่เหมือนกันตรงตามเงื่อนไขที่ระบุหรือไม่ | ไม่สามารถใช้ได้ | รวม ... ใน ... เป็นอะไรก็ได้ () |
ประกอบด้วย | ส่งคืนค่า 'True' หากพบว่ามีองค์ประกอบที่เฉพาะเจาะจงอยู่ในลำดับหากลำดับไม่มีองค์ประกอบนั้นค่า 'เท็จ' จะถูกส่งกลับ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ตัวดำเนินการพาร์ติชัน
แบ่งลำดับการป้อนข้อมูลออกเป็นสองส่วนแยกกันโดยไม่ต้องจัดเรียงองค์ประกอบของลำดับใหม่แล้วส่งคืนหนึ่งในนั้น
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
ข้าม | ข้ามจำนวนองค์ประกอบที่ระบุภายในลำดับและส่งคืนองค์ประกอบที่เหลือ | ไม่สามารถใช้ได้ | ข้าม |
ข้าม | เช่นเดียวกับการข้ามโดยมีข้อยกเว้นเพียงอย่างเดียวว่าจำนวนองค์ประกอบที่จะข้ามถูกระบุโดยเงื่อนไขบูลีน | ไม่สามารถใช้ได้ | ข้ามขณะ |
ใช้ | ใช้จำนวนองค์ประกอบที่ระบุจากลำดับและข้ามองค์ประกอบที่เหลือ | ไม่สามารถใช้ได้ | ใช้ |
TakeWhile | เช่นเดียวกับ Take ยกเว้นความจริงที่ว่าจำนวนองค์ประกอบที่จะใช้ถูกระบุโดยเงื่อนไขบูลีน | ไม่สามารถใช้ได้ | ใช้เวลาสักครู่ |
การดำเนินงานรุ่น
ลำดับใหม่ของค่าถูกสร้างขึ้นโดยตัวดำเนินการ generational
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
DefaultIfEmpty | เมื่อนำไปใช้กับลำดับว่างให้สร้างองค์ประกอบเริ่มต้นภายในลำดับ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ว่างเปล่า | ส่งคืนลำดับค่าว่างและเป็นตัวดำเนินการสร้างที่ง่ายที่สุด | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
พิสัย | สร้างคอลเล็กชันที่มีลำดับของจำนวนเต็มหรือตัวเลข | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ทำซ้ำ | สร้างลำดับที่มีค่าซ้ำของความยาวเฉพาะ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ตั้งค่าการทำงาน
มีตัวดำเนินการสี่ตัวสำหรับการดำเนินการเซ็ตแต่ละตัวให้ผลลัพธ์ตามเกณฑ์ที่แตกต่างกัน
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
โดดเด่น | แสดงรายการค่าที่ไม่ซ้ำกันจากคอลเล็กชันโดยการกรองข้อมูลที่ซ้ำกันหากมี | ไม่สามารถใช้ได้ | โดดเด่น |
ยกเว้น | เปรียบเทียบค่าของสองคอลเล็กชันและส่งคืนค่าจากคอลเล็กชันหนึ่งที่ไม่ได้อยู่ในคอลเล็กชันอื่น | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ตัด | ส่งคืนชุดค่าที่พบ t เหมือนกันในสองคอลเลกชันที่แยกจากกัน | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
สหภาพ | รวมเนื้อหาของคอลเล็กชันที่แตกต่างกันสองคอลเล็กชันไว้ในรายการเดียวโดยไม่มีเนื้อหาที่ซ้ำกัน | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ความเท่าเทียมกัน
เปรียบเทียบสองประโยค (แจกแจงได้) และพิจารณาว่าตรงกันหรือไม่
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
ลำดับ | ส่งผลลัพธ์เป็นค่าบูลีนหากพบว่าสองลำดับเหมือนกัน | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ตัวดำเนินการองค์ประกอบ
ยกเว้น DefaultIfEmpty ตัวดำเนินการองค์ประกอบแบบสอบถามมาตรฐานที่เหลือทั้งหมดแปดรายการจะส่งคืนองค์ประกอบเดียวจากคอลเลกชัน
แสดงตัวอย่าง
ตัวดำเนินการ | คำอธิบาย | ไวยากรณ์นิพจน์การค้นหา C # | VB Query Expression Syntax |
---|---|---|---|
ElementAt | ส่งคืนองค์ประกอบที่มีอยู่ภายในดัชนีเฉพาะในคอลเลกชัน | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ElementAtOrDefault | เช่นเดียวกับ ElementAt ยกเว้นข้อเท็จจริงที่ว่าจะส่งคืนค่าเริ่มต้นในกรณีที่ดัชนีเฉพาะอยู่นอกช่วง | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
อันดับแรก | ดึงข้อมูลองค์ประกอบแรกภายในคอลเลกชันหรือองค์ประกอบแรกที่ตรงตามเงื่อนไขเฉพาะ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
FirstOrDefault | เช่นเดียวกับ First ยกเว้นข้อเท็จจริงที่ว่าจะส่งคืนค่าเริ่มต้นในกรณีที่ไม่มีองค์ประกอบดังกล่าวอยู่ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
ล่าสุด | ดึงองค์ประกอบสุดท้ายที่มีอยู่ในคอลเลกชันหรือองค์ประกอบสุดท้ายที่เป็นไปตามเงื่อนไขเฉพาะ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
LastOrDefault | เหมือนกับ Last ยกเว้นข้อเท็จจริงที่ว่าจะส่งคืนค่าเริ่มต้นในกรณีที่ไม่มีองค์ประกอบดังกล่าวอยู่ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
โสด | ส่งคืนองค์ประกอบเดี่ยวของคอลเล็กชันหรือองค์ประกอบเดี่ยวที่เป็นไปตามเงื่อนไขบางประการ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
SingleOrDefault | เหมือนกับ Single ยกเว้นว่าจะส่งกลับค่าเริ่มต้นด้วยหากไม่มีองค์ประกอบเดี่ยวดังกล่าวอยู่ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
DefaultIfEmpty | ส่งคืนค่าเริ่มต้นหากคอลเล็กชันหรือรายการว่างเปล่าหรือเป็นโมฆะ | ไม่สามารถใช้ได้ | ไม่สามารถใช้ได้ |
LINQ เป็น SQL มีโครงสร้างพื้นฐาน (รันไทม์) สำหรับการจัดการข้อมูลเชิงสัมพันธ์เป็นวัตถุ เป็นส่วนประกอบของ. NET Framework เวอร์ชัน 3.5 และทำการแปลแบบสอบถามที่รวมภาษาของโมเดลอ็อบเจ็กต์เป็น SQL จากนั้นแบบสอบถามเหล่านี้จะถูกส่งไปยังฐานข้อมูลเพื่อวัตถุประสงค์ในการดำเนินการ หลังจากได้ผลลัพธ์จากฐานข้อมูลแล้ว LINQ เป็น SQL จะแปลเป็นวัตถุอีกครั้ง
การแนะนำ LINQ สู่ SQL
สำหรับนักพัฒนา ASP.NET ส่วนใหญ่ LINQ to SQL (หรือที่เรียกว่า DLINQ) เป็นส่วนที่ทำให้เกิดไฟฟ้าของ Language Integrated Query เนื่องจากอนุญาตให้สืบค้นข้อมูลในฐานข้อมูลเซิร์ฟเวอร์ SQL โดยใช้นิพจน์ LINQ ตามปกติ นอกจากนี้ยังอนุญาตให้อัปเดตลบและแทรกข้อมูล แต่ข้อเสียเปรียบเพียงประการเดียวคือข้อ จำกัด ของฐานข้อมูลเซิร์ฟเวอร์ SQL อย่างไรก็ตามมีประโยชน์มากมายของ LINQ กับ SQL บน ADO.NET เช่นความซับซ้อนที่ลดลงการเข้ารหัสไม่กี่บรรทัดและอื่น ๆ อีกมากมาย
ด้านล่างนี้เป็นแผนภาพที่แสดงสถาปัตยกรรมการดำเนินการของ LINQ เป็น SQL
จะใช้ LINQ เป็น SQL ได้อย่างไร?
Step 1- สร้าง "การเชื่อมต่อข้อมูล" ใหม่กับเซิร์ฟเวอร์ฐานข้อมูล ดู & arrar; เซิร์ฟเวอร์ Explorer & arrar; การเชื่อมต่อข้อมูล & arrar; เพิ่มการเชื่อมต่อ
Step 2 - เพิ่ม LINQ เป็นไฟล์คลาส SQL
Step 3 - เลือกตารางจากฐานข้อมูลแล้วลากและวางลงในไฟล์คลาส LINQ เป็น SQL ใหม่
Step 4 - เพิ่มตารางลงในไฟล์คลาส
การสืบค้นด้วย LINQ เป็น SQL
กฎสำหรับการดำเนินการสืบค้นด้วย LINQ ไปยัง SQL นั้นคล้ายกับของแบบสอบถาม LINQ มาตรฐานกล่าวคือการดำเนินการแบบสอบถามจะเลื่อนออกไปหรือทันที มีส่วนประกอบต่างๆที่มีบทบาทในการเรียกใช้แบบสอบถามด้วย LINQ ถึง SQL และมีดังต่อไปนี้
LINQ to SQL API - ร้องขอการดำเนินการค้นหาในนามของแอปพลิเคชันและส่งไปยัง LINQ ไปยังผู้ให้บริการ SQL
LINQ to SQL Provider - แปลงแบบสอบถามเป็น Transact SQL (T-SQL) และส่งแบบสอบถามใหม่ไปยังผู้ให้บริการ ADO เพื่อดำเนินการ
ADO Provider - หลังจากดำเนินการสืบค้นแล้วให้ส่งผลลัพธ์ในรูปแบบของ DataReader ไปยัง LINQ ไปยังผู้ให้บริการ SQL ซึ่งจะแปลงเป็นรูปแบบของวัตถุผู้ใช้
ควรสังเกตว่าก่อนดำเนินการแบบสอบถาม LINQ เป็น SQL จำเป็นอย่างยิ่งที่จะต้องเชื่อมต่อกับแหล่งข้อมูลผ่านคลาส DataContext
แทรกอัปเดตและลบโดยใช้ LINQ เป็น SQL
เพิ่มหรือแทรก
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);
//Create new Employee
Employee newEmployee = new Employee();
newEmployee.Name = "Michael";
newEmployee.Email = "[email protected]";
newEmployee.ContactNo = "343434343";
newEmployee.DepartmentId = 3;
newEmployee.Address = "Michael - USA";
//Add new Employee to database
db.Employees.InsertOnSubmit(newEmployee);
//Save changes to Database.
db.SubmitChanges();
//Get new Inserted Employee
Employee insertedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("Michael"));
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
insertedEmployee.EmployeeId, insertedEmployee.Name, insertedEmployee.Email,
insertedEmployee.ContactNo, insertedEmployee.Address);
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim newEmployee As New Employee()
newEmployee.Name = "Michael"
newEmployee.Email = "[email protected]"
newEmployee.ContactNo = "343434343"
newEmployee.DepartmentId = 3
newEmployee.Address = "Michael - USA"
db.Employees.InsertOnSubmit(newEmployee)
db.SubmitChanges()
Dim insertedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3},
Address = {4}", insertedEmployee.EmployeeId, insertedEmployee.Name,
insertedEmployee.Email, insertedEmployee.ContactNo, insertedEmployee.Address)
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างบนของ C # หรือ VB ถูกคอมไพล์และรันจะได้ผลลัพธ์ดังนี้ -
Emplyee ID = 4, Name = Michael, Email = [email protected], ContactNo =
343434343, Address = Michael - USA
Press any key to continue.
อัปเดต
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);
//Get Employee for update
Employee employee = db.Employees.FirstOrDefault(e =>e.Name.Equals("Michael"));
employee.Name = "George Michael";
employee.Email = "[email protected]";
employee.ContactNo = "99999999";
employee.DepartmentId = 2;
employee.Address = "Michael George - UK";
//Save changes to Database.
db.SubmitChanges();
//Get Updated Employee
Employee updatedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
updatedEmployee.EmployeeId, updatedEmployee.Name, updatedEmployee.Email,
updatedEmployee.ContactNo, updatedEmployee.Address);
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim employee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))
employee.Name = "George Michael"
employee.Email = "[email protected]"
employee.ContactNo = "99999999"
employee.DepartmentId = 2
employee.Address = "Michael George - UK"
db.SubmitChanges()
Dim updatedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3},
Address = {4}", updatedEmployee.EmployeeId, updatedEmployee.Name,
updatedEmployee.Email, updatedEmployee.ContactNo, updatedEmployee.Address)
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างบนของ C # หรือ Vb ถูกคอมไพล์และรันจะให้ผลลัพธ์ดังนี้ -
Emplyee ID = 4, Name = George Michael, Email = [email protected], ContactNo =
999999999, Address = Michael George - UK
Press any key to continue.
ลบ
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = newLinqToSQLDataContext(connectString);
//Get Employee to Delete
Employee deleteEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));
//Delete Employee
db.Employees.DeleteOnSubmit(deleteEmployee);
//Save changes to Database.
db.SubmitChanges();
//Get All Employee from Database
var employeeList = db.Employees;
foreach (Employee employee in employeeList) {
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim deleteEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))
db.Employees.DeleteOnSubmit(deleteEmployee)
db.SubmitChanges()
Dim employeeList = db.Employees
For Each employee As Employee In employeeList
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างบนของ C # หรือ VB ถูกคอมไพล์และรันจะได้ผลลัพธ์ดังนี้ -
Emplyee ID = 1, Name = William, Email = [email protected], ContactNo = 999999999
Emplyee ID = 2, Name = Miley, Email = [email protected], ContactNo = 999999999
Emplyee ID = 3, Name = Benjamin, Email = [email protected], ContactNo =
Press any key to continue.
LINQ to Objects นำเสนอการใช้แบบสอบถาม LINQ ใด ๆ ที่สนับสนุน IEnumerable <T> สำหรับการเข้าถึงคอลเลกชันข้อมูลในหน่วยความจำโดยไม่ต้องใช้ผู้ให้บริการ LINQ (API) ใด ๆ เช่นในกรณีของ LINQ เป็น SQL หรือ LINQ เป็น XML
การแนะนำ LINQ กับ Objects
แบบสอบถามใน LINQ ถึง Objects จะส่งคืนตัวแปรประเภทโดยปกติ IEnumerable <T> เท่านั้น กล่าวโดยย่อ LINQ to Objects นำเสนอแนวทางใหม่ในการรวบรวมเหมือนก่อนหน้านี้การเขียนโค้ดยาว ๆ (foreach loops ที่มีความซับซ้อนมาก) เพื่อการดึงข้อมูลจากคอลเล็กชันซึ่งปัจจุบันถูกแทนที่ด้วยการเขียนรหัสประกาศซึ่งอธิบายข้อมูลที่ต้องการอย่างชัดเจน ที่จำเป็นในการดึงข้อมูล
นอกจากนี้ยังมีข้อดีหลายประการของ LINQ to Objects ที่เหนือกว่า foreach loops แบบเดิม ๆ เช่นการอ่านได้มากขึ้นการกรองที่มีประสิทธิภาพความสามารถในการจัดกลุ่มการสั่งซื้อที่เพิ่มขึ้นโดยมีการเข้ารหัสแอปพลิเคชันน้อยที่สุด ข้อความค้นหา LINQ ดังกล่าวยังมีขนาดกะทัดรัดกว่าและสามารถพกพาไปยังแหล่งข้อมูลอื่น ๆ ได้โดยไม่ต้องแก้ไขใด ๆ หรือมีการปรับเปลี่ยนเพียงเล็กน้อย
ด้านล่างนี้เป็นตัวอย่าง LINQ to Objects อย่างง่าย -
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace LINQtoObjects {
class Program {
static void Main(string[] args) {
string[] tools = { "Tablesaw", "Bandsaw", "Planer", "Jointer", "Drill", "Sander" };
var list = from t in tools select t;
StringBuilder sb = new StringBuilder();
foreach (string s in list) {
sb.Append(s + Environment.NewLine);
}
Console.WriteLine(sb.ToString(), "Tools");
Console.ReadLine();
}
}
}
ในตัวอย่างอาร์เรย์ของสตริง (เครื่องมือ) ถูกใช้เป็นคอลเล็กชันของอ็อบเจ็กต์ที่จะสอบถามโดยใช้ LINQ to Objects
Objects query is:
var list = from t in tools select t;
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Tablesaw
Bandsaw
Planer
Jointer
Drill
Sander
การสืบค้นในคอลเลกชันหน่วยความจำโดยใช้ LINQ ไปยังวัตถุ
ค#
using System;
using System.Collections.Generic;
using System.Linq;
namespace LINQtoObjects {
class Department {
public int DepartmentId { get; set; }
public string Name { get; set; }
}
class LinqToObjects {
static void Main(string[] args) {
List<Department> departments = new List<Department>();
departments.Add(new Department { DepartmentId = 1, Name = "Account" });
departments.Add(new Department { DepartmentId = 2, Name = "Sales" });
departments.Add(new Department { DepartmentId = 3, Name = "Marketing" });
var departmentList = from d in departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Module Module1
Sub Main(ByVal args As String())
Dim account As New Department With {.Name = "Account", .DepartmentId = 1}
Dim sales As New Department With {.Name = "Sales", .DepartmentId = 2}
Dim marketing As New Department With {.Name = "Marketing", .DepartmentId = 3}
Dim departments As New System.Collections.Generic.List(Of Department)(New Department() {account, sales, marketing})
Dim departmentList = From d In departments
For Each dept In departmentList
Console.WriteLine("Department Id = {0} , Department Name = {1}", dept.DepartmentId, dept.Name)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Class Department
Public Property Name As String
Public Property DepartmentId As Integer
End Class
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Department Id = 1, Department Name = Account
Department Id = 2, Department Name = Sales
Department Id = 3, Department Name = Marketing
Press any key to continue.
ชุดข้อมูลนำเสนอการแสดงข้อมูลที่มีประโยชน์อย่างยิ่งในหน่วยความจำและใช้สำหรับแอปพลิเคชันที่ใช้ข้อมูลที่หลากหลาย LINQ to Dataset เป็นหนึ่งในเทคโนโลยีของ LINQ to ADO.NET ช่วยอำนวยความสะดวกในการดำเนินการสืบค้นข้อมูลของชุดข้อมูลในลักษณะที่ไม่ยุ่งยากและเพิ่มประสิทธิผล
การแนะนำ LINQ ไปยังชุดข้อมูล
LINQ to Dataset ทำให้งานในการสืบค้นเป็นเรื่องง่ายสำหรับนักพัฒนา พวกเขาไม่จำเป็นต้องเขียนคำค้นหาในภาษาแบบสอบถามที่เฉพาะเจาะจง แต่สามารถเขียนในภาษาโปรแกรมได้ LINQ เป็น Dataset ยังสามารถใช้สำหรับการสืบค้นข้อมูลที่รวมจากแหล่งข้อมูลหลายแหล่ง สิ่งนี้ไม่จำเป็นต้องมีผู้ให้บริการ LINQ เช่นเดียวกับ LINQ ถึง SQL และ LINQ เป็น XML สำหรับการเข้าถึงข้อมูลจากในคอลเลกชันหน่วยความจำ
ด้านล่างนี้เป็นตัวอย่างง่ายๆของแบบสอบถาม LINQ to Dataset ซึ่งได้รับแหล่งข้อมูลก่อนจากนั้นชุดข้อมูลจะเต็มไปด้วยตารางข้อมูลสองตาราง ความสัมพันธ์ถูกสร้างขึ้นระหว่างทั้งตารางและแบบสอบถาม LINQ ถูกสร้างขึ้นกับทั้งสองตารางโดยใช้อนุประโยคเข้าร่วม สุดท้าย foreach loop ใช้เพื่อแสดงผลลัพธ์ที่ต้องการ
ค#
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace LINQtoDataset {
class Program {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
string sqlSelect = "SELECT * FROM Department;" + "SELECT * FROM Employee;";
// Create the data adapter to retrieve data from the database
SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);
// Create table mappings
da.TableMappings.Add("Table", "Department");
da.TableMappings.Add("Table1", "Employee");
// Create and fill the DataSet
DataSet ds = new DataSet();
da.Fill(ds);
DataRelation dr = ds.Relations.Add("FK_Employee_Department",
ds.Tables["Department"].Columns["DepartmentId"],
ds.Tables["Employee"].Columns["DepartmentId"]);
DataTable department = ds.Tables["Department"];
DataTable employee = ds.Tables["Employee"];
var query = from d in department.AsEnumerable()
join e in employee.AsEnumerable()
on d.Field<int>("DepartmentId") equals
e.Field<int>("DepartmentId")
select new {
EmployeeId = e.Field<int>("EmployeeId"),
Name = e.Field<string>("Name"),
DepartmentId = d.Field<int>("DepartmentId"),
DepartmentName = d.Field<string>("Name")
};
foreach (var q in query) {
Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}",
q.EmployeeId, q.Name, q.DepartmentName);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Data.SqlClient
Imports System.Linq
Module LinqToDataSet
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim sqlSelect As String = "SELECT * FROM Department;" + "SELECT * FROM Employee;"
Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
sqlCnn.Open()
Dim da As New SqlDataAdapter
da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)
da.TableMappings.Add("Table", "Department")
da.TableMappings.Add("Table1", "Employee")
Dim ds As New DataSet()
da.Fill(ds)
Dim dr As DataRelation = ds.Relations.Add("FK_Employee_Department", ds.Tables("Department").Columns("DepartmentId"), ds.Tables("Employee").Columns("DepartmentId"))
Dim department As DataTable = ds.Tables("Department")
Dim employee As DataTable = ds.Tables("Employee")
Dim query = From d In department.AsEnumerable()
Join e In employee.AsEnumerable() On d.Field(Of Integer)("DepartmentId") Equals
e.Field(Of Integer)("DepartmentId")
Select New Person With { _
.EmployeeId = e.Field(Of Integer)("EmployeeId"),
.EmployeeName = e.Field(Of String)("Name"),
.DepartmentId = d.Field(Of Integer)("DepartmentId"),
.DepartmentName = d.Field(Of String)("Name")
}
For Each e In query
Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}", e.EmployeeId, e.EmployeeName, e.DepartmentName)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Class Person
Public Property EmployeeId As Integer
Public Property EmployeeName As String
Public Property DepartmentId As Integer
Public Property DepartmentName As String
End Class
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Employee Id = 1, Name = William, Department Name = Account
Employee Id = 2, Name = Benjamin, Department Name = Account
Employee Id = 3, Name = Miley, Department Name = Sales
Press any key to continue.
การสืบค้นชุดข้อมูลโดยใช้ LinQ ไปยังชุดข้อมูล
ก่อนที่จะเริ่มค้นหาชุดข้อมูลโดยใช้ LINQ เป็นชุดข้อมูลจำเป็นอย่างยิ่งที่จะต้องโหลดข้อมูลไปยังชุดข้อมูลและทำได้โดยใช้คลาส DataAdapter หรือโดย LINQ ไปยัง SQL การสร้างแบบสอบถามโดยใช้ LINQ เป็นชุดข้อมูลค่อนข้างคล้ายกับการสร้างแบบสอบถามโดยใช้ LINQ ร่วมกับแหล่งข้อมูลอื่น ๆ ที่เปิดใช้งาน LINQ
แบบสอบถามตารางเดียว
ในแบบสอบถามตารางเดียวต่อไปนี้ใบสั่งออนไลน์ทั้งหมดจะถูกรวบรวมจาก SalesOrderHeaderTtable จากนั้นรหัสคำสั่งซื้อวันที่สั่งซื้อและหมายเลขใบสั่งจะแสดงเป็นผลลัพธ์
C#
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace LinqToDataset {
class SingleTable {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
string sqlSelect = "SELECT * FROM Department;";
// Create the data adapter to retrieve data from the database
SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);
// Create table mappings
da.TableMappings.Add("Table", "Department");
// Create and fill the DataSet
DataSet ds = new DataSet();
da.Fill(ds);
DataTable department = ds.Tables["Department"];
var query = from d in department.AsEnumerable()
select new {
DepartmentId = d.Field<int>("DepartmentId"),
DepartmentName = d.Field<string>("Name")
};
foreach (var q in query) {
Console.WriteLine("Department Id = {0} , Name = {1}",
q.DepartmentId, q.DepartmentName);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Data.SqlClient
Imports System.Linq
Module LinqToDataSet
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim sqlSelect As String = "SELECT * FROM Department;"
Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
sqlCnn.Open()
Dim da As New SqlDataAdapter
da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)
da.TableMappings.Add("Table", "Department")
Dim ds As New DataSet()
da.Fill(ds)
Dim department As DataTable = ds.Tables("Department")
Dim query = From d In department.AsEnumerable()
Select New DepartmentDetail With {
.DepartmentId = d.Field(Of Integer)("DepartmentId"),
.DepartmentName = d.Field(Of String)("Name")
}
For Each e In query
Console.WriteLine("Department Id = {0} , Name = {1}", e.DepartmentId, e.DepartmentName)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Public Class DepartmentDetail
Public Property DepartmentId As Integer
Public Property DepartmentName As String
End Class
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Department Id = 1, Name = Account
Department Id = 2, Name = Sales
Department Id = 3, Name = Pre-Sales
Department Id = 4, Name = Marketing
Press any key to continue.
LINQ เป็น XML ช่วยให้สามารถเข้าถึงฟังก์ชัน LINQ ทั้งหมดได้อย่างง่ายดายเช่นตัวดำเนินการสืบค้นมาตรฐานอินเทอร์เฟซการเขียนโปรแกรม ฯลฯ รวมอยู่ในกรอบ. NET LINQ เป็น XML ยังใช้ประโยชน์จากฟังก์ชัน. และอื่น ๆ อีกมากมายที่จะพูด
การแนะนำ LINQ เป็น XML
ในขณะที่ใช้ LINQ เป็น XML การโหลดเอกสาร XML ลงในหน่วยความจำทำได้ง่ายและง่ายกว่าคือการสอบถามและการแก้ไขเอกสาร นอกจากนี้ยังสามารถบันทึกเอกสาร XML ที่มีอยู่ในหน่วยความจำลงในดิสก์และทำให้เป็นอนุกรมได้ ไม่จำเป็นต้องให้นักพัฒนาเรียนรู้ภาษาคิวรี XML ซึ่งค่อนข้างซับซ้อน
LINQ เป็น XML มีอำนาจในเนมสเปซ System.Xml.Linq นี่มีคลาสที่จำเป็นทั้งหมด 19 คลาสเพื่อทำงานกับ XML ชั้นเรียนเหล่านี้มีดังต่อไปนี้
- XAttribute
- XCData
- XComment
- XContainer
- XDeclaration
- XDocument
- XDocumentType
- XElement
- XName
- XNamespace
- XNode
- XNodeDocumentOrderComparer
- XNodeEqualityComparer
- XObject
- XObjectChange
- XObjectChangeEventArgs
- XObjectEventHandler
- XProcessingInstruction
- XText
อ่านไฟล์ XML โดยใช้ LINQ
ค#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(ByVal args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing
Press any key to continue.
เพิ่มโหนดใหม่
ค#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
//Add new Element
xdoc.Element("Departments").Add(new XElement("Department", "Finance"));
//Add new Element at First
xdoc.Element("Departments").AddFirst(new XElement("Department", "Support"));
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(ByVal args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
xdoc.Element("Departments").Add(New XElement("Department", "Finance"))
xdoc.Element("Departments").AddFirst(New XElement("Department", "Support"))
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Department Name - Support
Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance
Press any key to continue.
การลบโหนดเฉพาะ
ค#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Support</Department>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
<Department>Finance</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
//Remove Sales Department
xdoc.Descendants().Where(s =>s.Value == "Sales").Remove();
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Support</Department>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"<Department>Finance</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
xdoc.Descendants().Where(Function(s) s.Value = "Sales").Remove()
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
Department Name - Support
Department Name - Account
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance
Press any key to continue.
ส่วนหนึ่งของ ADO.NET Entity Framework LINQ to Entities มีความยืดหยุ่นมากกว่า LINQ เป็น SQL แต่ไม่ได้รับความนิยมมากนักเนื่องจากมีความซับซ้อนและขาดคุณสมบัติหลัก อย่างไรก็ตามไม่มีข้อ จำกัด ของ LINQ กับ SQL ที่อนุญาตให้สืบค้นข้อมูลได้เฉพาะในฐานข้อมูลเซิร์ฟเวอร์ SQL เนื่องจาก LINQ to Entities ช่วยอำนวยความสะดวกในการสืบค้นข้อมูลในผู้ให้บริการข้อมูลจำนวนมากเช่น Oracle, MySQL และอื่น ๆ
ยิ่งไปกว่านั้นยังได้รับการสนับสนุนที่สำคัญจาก ASP.Net ในแง่ที่ผู้ใช้สามารถใช้ประโยชน์จากการควบคุมแหล่งข้อมูลเพื่อดำเนินการค้นหาผ่าน LINQ ไปยังเอนทิตีและอำนวยความสะดวกในการผูกผลลัพธ์โดยไม่จำเป็นต้องมีการเข้ารหัสเพิ่มเติม
LINQ to Entities มีข้อดีเหล่านี้กลายเป็นกลไกมาตรฐานสำหรับการใช้งาน LINQ บนฐานข้อมูลในปัจจุบัน นอกจากนี้ยังเป็นไปได้ด้วย LINQ to Entities เพื่อเปลี่ยนรายละเอียดข้อมูลที่สอบถามและทำการอัปเดตเป็นกลุ่ม ข้อเท็จจริงที่น่าสนใจที่สุดเกี่ยวกับ LINQ to Entities คือมีไวยากรณ์เหมือนกันกับ SQL และยังมีกลุ่มตัวดำเนินการสืบค้นมาตรฐานเดียวกันเช่น Join, Select, OrderBy เป็นต้น
LINQ ไปยังเอนทิตีการสร้างคิวรีและกระบวนการดำเนินการ
การก่อสร้าง ObjectQuery อินสแตนซ์จากไฟล์ ObjectContext (การเชื่อมต่อเอนทิตี)
การเขียนแบบสอบถามใน C # หรือ Visual Basic (VB) โดยใช้อินสแตนซ์ที่สร้างขึ้นใหม่
การแปลงตัวดำเนินการเคียวรีมาตรฐานของ LINQ ตลอดจนนิพจน์ LINQ เป็นแผนผังคำสั่ง
การดำเนินการค้นหาโดยส่งข้อยกเว้นใด ๆ ที่พบไปยังไคลเอ็นต์โดยตรง
กลับไปยังไคลเอนต์ผลการค้นหาทั้งหมด
ObjectContext นี่คือคลาสหลักที่เปิดใช้งานการโต้ตอบกับ Entity Data Modelหรือกล่าวอีกนัยหนึ่งทำหน้าที่เป็นสะพานที่เชื่อมต่อ LINQ กับฐานข้อมูล ต้นไม้คำสั่งเป็นตัวแทนของแบบสอบถามที่เข้ากันได้กับกรอบงานเอนทิตี
ในทางกลับกัน Entity Framework นั้นเป็นจริง Object Relational Mapperโดยทั่วไปเรียกย่อว่า ORM โดยนักพัฒนาที่สร้างวัตถุทางธุรกิจเช่นเดียวกับเอนทิตีตามตารางฐานข้อมูลและอำนวยความสะดวกในการดำเนินการขั้นพื้นฐานต่างๆเช่นสร้างอัปเดตลบและอ่าน ภาพประกอบต่อไปนี้แสดงกรอบงานเอนทิตีและส่วนประกอบต่างๆ
ตัวอย่างของ ADD, UPDATE และ DELETE โดยใช้ LINQ กับ Entity Model
ขั้นแรกให้เพิ่ม Entity Model โดยทำตามขั้นตอนด้านล่าง
Step 1- คลิกขวาที่โครงการและคลิกเพิ่มรายการใหม่จะเปิดหน้าต่างตามด้านล่าง เลือก ADO.NET Entity Data Model และระบุชื่อและคลิกที่ Add
Step 2 - เลือก Generate from database.
Step 3 - เลือกการเชื่อมต่อฐานข้อมูลจากเมนูแบบเลื่อนลง
Step 4 - เลือกตารางทั้งหมด
ตอนนี้เขียนโค้ดต่อไปนี้
using DataAccess;
using System;
using System.Linq;
namespace LINQTOSQLConsoleApp {
public class LinqToEntityModel {
static void Main(string[] args) {
using (LinqToSQLDBEntities context = new LinqToSQLDBEntities()) {
//Get the List of Departments from Database
var departmentList = from d in context.Departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
//Add new Department
DataAccess.Department department = new DataAccess.Department();
department.Name = "Support";
context.Departments.Add(department);
context.SaveChanges();
Console.WriteLine("Department Name = Support is inserted in Database");
//Update existing Department
DataAccess.Department updateDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 1);
updateDepartment.Name = "Account updated";
context.SaveChanges();
Console.WriteLine("Department Name = Account is updated in Database");
//Delete existing Department
DataAccess.Department deleteDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 3);
context.Departments.Remove(deleteDepartment);
context.SaveChanges();
Console.WriteLine("Department Name = Pre-Sales is deleted in Database");
//Get the Updated List of Departments from Database
departmentList = from d in context.Departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
คำว่า 'นิพจน์แลมบ์ดา' ได้ชื่อมาจากแคลคูลัส 'แลมด้า' ซึ่งเป็นสัญกรณ์ทางคณิตศาสตร์ที่ใช้ในการกำหนดฟังก์ชัน นิพจน์แลมบ์ดาเป็นส่วนที่เรียกใช้งานได้ของสมการ LINQ แปลลอจิกในลักษณะที่รันไทม์เพื่อให้สามารถส่งต่อไปยังแหล่งข้อมูลได้อย่างสะดวก อย่างไรก็ตามนิพจน์แลมบ์ดาไม่ได้ จำกัด เพียงการค้นหาแอปพลิเคชันใน LINQ เท่านั้น
นิพจน์เหล่านี้แสดงโดยไวยากรณ์ต่อไปนี้ -
(Input parameters) ⇒ Expression or statement block
นี่คือตัวอย่างของนิพจน์แลมบ์ดา -
y ⇒ y * y
นิพจน์ด้านบนระบุพารามิเตอร์ชื่อ y และค่าของ y เป็นกำลังสอง อย่างไรก็ตามไม่สามารถเรียกใช้นิพจน์แลมบ์ดาในรูปแบบนี้ได้ ตัวอย่างนิพจน์แลมบ์ดาใน C # แสดงไว้ด้านล่าง
ค#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
delegate int del(int i);
static void Main(string[] args) {
del myDelegate = y ⇒ y * y;
int j = myDelegate(5);
Console.WriteLine(j);
Console.ReadLine();
}
}
}
VB
Module Module1
Private Delegate Function del(ByVal i As Integer) As Integer
Sub Main(ByVal args As String())
Dim myDelegate As del = Function(y) y * y
Dim j As Integer = myDelegate(5)
Console.WriteLine(j)
Console.ReadLine()
End Sub
End Module
เมื่อโค้ดข้างต้นของ C # หรือ VB ถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
25
นิพจน์แลมด้า
เนื่องจากนิพจน์ในไวยากรณ์ของแลมบ์ดานิพจน์ที่แสดงด้านบนอยู่ทางด้านขวามือจึงเรียกอีกอย่างหนึ่งว่านิพจน์แลมด้า
Async Lambdas
นิพจน์แลมบ์ดาที่สร้างขึ้นโดยรวมการประมวลผลแบบอะซิงโครนัสโดยการใช้คำสำคัญแบบอะซิงโครนัสเรียกว่า async lambdas ด้านล่างนี้เป็นตัวอย่างของ async lambda
Func<Task<string>> getWordAsync = async()⇒ “hello”;
แลมบ์ดาในตัวดำเนินการสืบค้นมาตรฐาน
นิพจน์แลมบ์ดาภายในตัวดำเนินการแบบสอบถามจะได้รับการประเมินตามความต้องการและทำงานอย่างต่อเนื่องกับแต่ละองค์ประกอบในลำดับการป้อนข้อมูลไม่ใช่ลำดับทั้งหมด นักพัฒนาได้รับอนุญาตโดยนิพจน์ Lambda ให้ป้อนตรรกะของตนเองลงในตัวดำเนินการสืบค้นมาตรฐาน ในตัวอย่างด้านล่างนักพัฒนาได้ใช้ตัวดำเนินการ 'Where' เพื่อเรียกคืนค่าแปลกจากรายการที่กำหนดโดยใช้นิพจน์แลมบ์ดา
ค#
//Get the average of the odd Fibonacci numbers in the series...
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
static void Main(string[] args) {
int[] fibNum = { 1, 1, 2, 3, 5, 8, 13, 21, 34 };
double averageValue = fibNum.Where(num ⇒ num % 2 == 1).Average();
Console.WriteLine(averageValue);
Console.ReadLine();
}
}
}
VB
Module Module1
Sub Main()
Dim fibNum As Integer() = {1, 1, 2, 3, 5, 8, 13, 21, 34}
Dim averageValue As Double = fibNum.Where(Function(num) num Mod 2 = 1).Average()
Console.WriteLine(averageValue)
Console.ReadLine()
End Sub
End Module
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
7.33333333333333
พิมพ์ Inference ใน Lambda
ใน C # การอนุมานประเภทถูกใช้อย่างสะดวกในสถานการณ์ต่างๆและเช่นกันโดยไม่ต้องระบุประเภทอย่างชัดเจน อย่างไรก็ตามในกรณีของนิพจน์แลมบ์ดาการอนุมานประเภทจะใช้ได้ผลก็ต่อเมื่อระบุแต่ละประเภทตามที่คอมไพลเลอร์ต้องเป็นที่พอใจ ลองพิจารณาตัวอย่างต่อไปนี้
delegate int Transformer (int i);
ที่นี่คอมไพเลอร์ใช้การอนุมานประเภทเพื่อดึงข้อเท็จจริงที่ว่า x เป็นจำนวนเต็มและทำได้โดยการตรวจสอบประเภทพารามิเตอร์ของ Transformer
ขอบเขตตัวแปรใน Lambda Expression
มีกฎบางอย่างในขณะที่ใช้ขอบเขตตัวแปรในนิพจน์แลมบ์ดาเช่นตัวแปรที่เริ่มต้นภายในนิพจน์แลมบ์ดาไม่ได้หมายความว่าจะมองเห็นได้ด้วยวิธีภายนอก นอกจากนี้ยังมีกฎว่าห้ามเก็บตัวแปรที่จับไว้เป็นขยะเว้นแต่ผู้รับมอบสิทธิ์ที่อ้างถึงสิ่งเดียวกันจะมีสิทธิ์ได้รับการรวบรวมขยะ ยิ่งไปกว่านั้นมีกฎที่ห้ามไม่ให้คำสั่งส่งคืนภายในนิพจน์แลมบ์ดาทำให้เกิดการส่งคืนวิธีการปิดล้อม
นี่คือตัวอย่างเพื่อแสดงขอบเขตตัวแปรในนิพจน์แลมบ์ดา
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
delegate bool D();
delegate bool D2(int i);
class Test {
D del;
D2 del2;
public void TestMethod(int input) {
int j = 0;
// Initialize the delegates with lambda expressions.
// Note access to 2 outer variables.
// del will be invoked within this method.
del = () ⇒ { j = 10; return j > input; };
// del2 will be invoked after TestMethod goes out of scope.
del2 = (x) ⇒ { return x == j; };
// Demonstrate value of j:
// The delegate has not been invoked yet.
Console.WriteLine("j = {0}", j); // Invoke the delegate.
bool boolResult = del();
Console.WriteLine("j = {0}. b = {1}", j, boolResult);
}
static void Main() {
Test test = new Test();
test.TestMethod(5);
// Prove that del2 still has a copy of
// local variable j from TestMethod.
bool result = test.del2(10);
Console.WriteLine(result);
Console.ReadKey();
}
}
}
}
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
j = 0
j = 10. b = True
True
ต้นไม้นิพจน์
ใช้นิพจน์แลมบ์ดาใน Expression Treeการก่อสร้างอย่างกว้างขวาง แผนภูมินิพจน์ให้รหัสในโครงสร้างข้อมูลที่คล้ายกับต้นไม้ซึ่งทุกโหนดเป็นนิพจน์เช่นการเรียกใช้เมธอดหรืออาจเป็นการดำเนินการแบบไบนารีเช่น x <y ด้านล่างนี้เป็นตัวอย่างของการใช้นิพจน์แลมบ์ดาสำหรับการสร้างแผนภูมินิพจน์
คำชี้แจงแลมด้า
นอกจากนี้ยังมี statement lambdasประกอบด้วยสองหรือสามคำสั่ง แต่ไม่ได้ใช้ในการสร้างแผนภูมินิพจน์ คำสั่งส่งคืนต้องเขียนในคำสั่ง lambda
ไวยากรณ์ของคำสั่ง lambda
(params)⇒ {statements}
ตัวอย่างคำสั่ง lambda
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;
namespace lambdaexample {
class Program {
static void Main(string[] args) {
int[] source = new[] { 3, 8, 4, 6, 1, 7, 9, 2, 4, 8 };
foreach (int i in source.Where(x ⇒
{
if (x <= 3)
return true;
else if (x >= 7)
return true;
return false;
}
))
Console.WriteLine(i);
Console.ReadLine();
}
}
}
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -
3
8
1
7
9
2
8
Lambdas ถูกใช้เป็นอาร์กิวเมนต์ในการสืบค้น LINQ ตามวิธีการและไม่อนุญาตให้มีที่ทางด้านซ้ายของตัวดำเนินการเช่น is หรือ asเช่นเดียวกับวิธีการที่ไม่ระบุชื่อ แม้ว่านิพจน์แลมบ์ดาจะเหมือนกับวิธีการที่ไม่ระบุตัวตน แต่ก็ไม่ได้ จำกัด ให้ใช้เป็นตัวแทนเท่านั้น
สิ่งที่ต้องจำขณะใช้นิพจน์แลมบ์ดา
นิพจน์แลมบ์ดาสามารถส่งคืนค่าและอาจมีพารามิเตอร์
พารามิเตอร์สามารถกำหนดได้หลายวิธีด้วยนิพจน์แลมบ์ดา
หากมีคำสั่งเดียวในนิพจน์แลมบ์ดาไม่จำเป็นต้องมีวงเล็บปีกกาในขณะที่มีหลายคำสั่งวงเล็บปีกกาและค่าส่งคืนเป็นสิ่งสำคัญในการเขียน
ด้วยนิพจน์แลมบ์ดาทำให้สามารถเข้าถึงตัวแปรที่อยู่นอกบล็อกนิพจน์แลมบ์ดาโดยคุณลักษณะที่เรียกว่าการปิด ควรใช้การปิดอย่างระมัดระวังเพื่อหลีกเลี่ยงปัญหา
เป็นไปไม่ได้ที่จะรันโค้ดที่ไม่ปลอดภัยภายในนิพจน์แลมบ์ดาใด ๆ
นิพจน์แลมบ์ดาไม่ได้หมายถึงการใช้ทางด้านซ้ายของตัวดำเนินการ
ในฐานะที่เป็นชุดของส่วนขยาย. NET framework LINQ เป็นกลไกที่ต้องการสำหรับการเข้าถึงข้อมูลโดยนักพัฒนา ASP.NET ASP.NET 3.5 มีเครื่องมือในตัวการควบคุม LINQDataSource ที่ช่วยให้ใช้งาน LINQ ได้อย่างง่ายดายใน ASP.NET ASP.NET ใช้ตัวควบคุมที่กล่าวถึงข้างต้นเป็นแหล่งข้อมูล โครงการในชีวิตจริงส่วนใหญ่ครอบคลุมเว็บไซต์หรือแอปพลิเคชัน Windows ดังนั้นเพื่อให้เข้าใจแนวคิดของ LINQ กับ ASP.NET ได้ดีขึ้นเริ่มต้นด้วยการสร้างเว็บไซต์ ASP.NET ที่ใช้ประโยชน์จากคุณสมบัติ LINQ
สำหรับสิ่งนี้จำเป็นอย่างยิ่งที่จะต้องติดตั้ง Visual Studio และ. NET framework บนระบบของคุณ เมื่อคุณเปิด Visual Studio แล้วให้ไปที่ไฟล์→ใหม่→เว็บไซต์ หน้าต่างป๊อปอัปจะเปิดขึ้นตามที่แสดงในรูปด้านล่าง
ตอนนี้ใต้เทมเพลตทางด้านซ้ายมือจะมีตัวเลือกสองภาษาในการสร้างเว็บไซต์ เลือกVisual C# และเลือก ASP.NET Empty Web Site.
เลือกโฟลเดอร์ที่คุณต้องการบันทึกเว็บไซต์ใหม่ในระบบของคุณ จากนั้นกดOK และเร็ว ๆ นี้ Solution Explorerปรากฏบนหน้าจอของคุณที่มีไฟล์เว็บทั้งหมด คลิกขวาที่ Default.aspx ใน Solution Explorer และเลือก View in Browser เพื่อดูเว็บไซต์ ASP.NET เริ่มต้นในเบราว์เซอร์ ในไม่ช้าเว็บไซต์ ASP.NET ใหม่ของคุณจะเปิดขึ้นในเว็บเบราว์เซอร์ดังที่แสดงในภาพหน้าจอต่อไปนี้
.aspx เป็นนามสกุลไฟล์หลักที่ใช้ในเว็บไซต์ ASP.NET โดยค่าเริ่มต้น Visual Studio จะสร้างเพจที่จำเป็นทั้งหมดสำหรับเว็บไซต์พื้นฐานเช่นHome page และ About Usหน้าที่คุณสามารถวางเนื้อหาของคุณได้อย่างสะดวก รหัสสำหรับเว็บไซต์จะถูกสร้างขึ้นโดยอัตโนมัติที่นี่และสามารถดูได้ด้วย
การควบคุม LINQDataSource
เป็นไปได้ที่จะ UPDATE, INSERT และ DELETEข้อมูลในหน้าของเว็บไซต์ ASP.NET ด้วยความช่วยเหลือของการควบคุม LINQDataSource ไม่จำเป็นต้องมีข้อกำหนดเฉพาะของคำสั่ง SQL เนื่องจากการควบคุม LINQDataSource ใช้คำสั่งที่สร้างขึ้นแบบไดนามิกสำหรับการดำเนินการดังกล่าว
การควบคุมช่วยให้ผู้ใช้สามารถใช้ LINQ ในเว็บเพจ ASP.NET ได้อย่างสะดวกสบายโดยการตั้งค่าคุณสมบัติในข้อความมาร์กอัป LINQDataSource คล้ายกับการควบคุมเช่นSqlDataSource เช่นเดียวกับ ObjectDataSourceเนื่องจากสามารถใช้ในการเชื่อมโยงตัวควบคุม ASP.NET อื่น ๆ ที่มีอยู่บนเพจกับแหล่งข้อมูล ดังนั้นเราต้องมีไฟล์database เพื่ออธิบายฟังก์ชันต่างๆที่เรียกใช้โดย LINQDataSource Control
ก่อนที่จะเริ่มอธิบายการใช้งานการควบคุมในฟอร์มหน้าเว็บ ASP.NET จำเป็นอย่างยิ่งที่จะต้องเปิด Microsoft Visual Studio Toolbox แล้วลากและวางการควบคุม LINQDataSource ไปที่หน้า. aspx ของเว็บไซต์ ASP.NET ดังรูปด้านล่าง
ขั้นตอนต่อไปคือการกำหนดค่า LINQDataSource โดยเลือกคอลัมน์ทั้งหมดสำหรับบันทึกพนักงาน
ตอนนี้เพิ่ม GridView Control ในหน้า. aspx และกำหนดค่าตามที่แสดงในรูปด้านล่าง การควบคุม GridView มีประสิทธิภาพและมีความยืดหยุ่นในการทำงานกับข้อมูล หลังจากกำหนดค่าการควบคุมไม่นานก็จะปรากฏในเบราว์เซอร์
การเข้ารหัสที่สามารถดูได้บนหน้าจอของคุณสำหรับหน้า. aspx จะเป็น -
<!DOCTYPE html>
<html>
<head runat = "server">
<title></title>
</head>
<body>
<form id = "form1" runat = "server">
<div>
<asp:GridView ID = "GridView1" runat = "server" AutoGenerateColumns = "False"
DataKeyNames = "ContactID" DataSourceID = "LINQDataSource1">
<Columns>
<asp:BoundField DataField = "ContactID" HeaderText = "ContactID"
InsertVisible = "False" ReadOnly="True" SortExpression = "ContactID" />
<asp:CheckBoxField DataField = "NameStyle" HeaderText = "NameStyle"
SortExpression = "NameStyle" />
<asp:BoundField DataField = "Title" HeaderText = "Title" SortExpression = "Title" />
<asp:BoundField DataField = "FirstName" HeaderText = "FirstName"
SortExpression="FirstName" />
<asp:BoundField DataField = "MiddleName" HeaderText = "MiddleName"
SortExpression = "MiddleName" />
<asp:BoundField DataField = "LastName" HeaderText = "LastName"
SortExpression = "LastName" />
<asp:BoundField DataField = "Suffix" HeaderText = "Suffix"
SortExpression = "Suffix" />
<asp:BoundField DataField = "EmailAddress" HeaderText = "EmailAddress"
SortExpression = "EmailAddress" />
</Columns>
</asp:GridView>
<br />
</div>
<asp:LINQDataSource ID = "LINQDataSource1" runat = "server"
ContextTypeName = "LINQWebApp1.AdventureWorksDataContext" EntityTypeName = ""
TableName = "Contacts">
</asp:LINQDataSource>
</form>
</body>
</html>
ที่นี่ควรสังเกตว่าการตั้งค่าคุณสมบัติ ContextTypeName เป็นของคลาสที่เป็นตัวแทนฐานข้อมูลมีความสำคัญ ตัวอย่างเช่นในที่นี้จะกำหนดเป็น LINQWebApp1.AdventureWorksDataContext เนื่องจากการดำเนินการนี้จะทำให้การเชื่อมต่อที่จำเป็นระหว่าง LINQDataSource และฐานข้อมูล
แทรกอัปเดตและลบข้อมูลใน ASP.NET เพจโดยใช้ LINQ
หลังจากทำตามขั้นตอนข้างต้นทั้งหมดอย่างเข้มงวดแล้วให้เลือกไฟล์ LINQDataSource Tasks จาก LINQDataSource Control และเลือกทั้งสามช่องเพื่อเปิดใช้งานการแทรกเปิดใช้งานการอัปเดตและเปิดใช้งานการลบจากเดียวกันดังที่แสดงในภาพหน้าจอต่อไปนี้
ในไม่ช้ามาร์กอัปที่เปิดเผยจะปรากฏบนหน้าจอของคุณดังรายการต่อไปนี้
<asp:LINQDataSource
ContextTypeName = "LINQWebApp1.AdventureWorksDataContext"
TableName = "Contacts"
EnableUpdate = "true"
EnableInsert = "true"
EnableDelete = "true"
ID = "LINQDataSource1"
runat = "server">
</asp:LINQDataSource>
ตอนนี้เนื่องจากมีหลายแถวและคอลัมน์จึงเป็นการดีกว่าที่จะเพิ่มตัวควบคุมอื่นในฟอร์ม. aspx ของคุณที่ชื่อเป็นมุมมองรายละเอียดหรือตัวควบคุมหลักด้านล่างตัวควบคุมมุมมองตารางเพื่อแสดงเฉพาะรายละเอียดของแถวที่เลือกของตาราง เลือกงานมุมมองรายละเอียดจากตัวควบคุมมุมมองรายละเอียดและเลือกกล่องกาเครื่องหมายดังที่แสดงด้านล่าง
ตอนนี้เพียงแค่บันทึกการเปลี่ยนแปลงแล้วกด Ctrl + F5 เพื่อดูเพจในเบราว์เซอร์ของคุณซึ่งตอนนี้คุณสามารถลบอัปเดตแทรกบันทึกใด ๆ บนตัวควบคุมมุมมองรายละเอียดได้