Langkau dan Ambil dalam SQL: Setara LINQ
Kaedah .Skip() dan .Take() LINQ menyediakan cara yang mudah untuk berfungsi dengan subset data dalam ingatan. Walau bagaimanapun, dalam situasi di mana sumber data asas ialah pangkalan data SQL yang besar, selalunya lebih baik untuk melaksanakan operasi ini secara langsung dalam SQL dan bukannya dalam ingatan. Ini mengelakkan overhed memindahkan sejumlah besar data ke dalam memori.
Satu senario sedemikian ialah apabila anda perlu memilih julat baris tertentu daripada jadual pangkalan data. LINQ menyediakan kaedah .Skip() dan .Take() untuk tujuan ini, tetapi adakah terdapat persamaan SQL langsung?
SQL Server 2012 and Above
SQL Server 2012 dan ke atas memperkenalkan sintaks baharu untuk mengimbangi baris dan mengehadkan:
OFFSET (@Skip) ROWS FETCH NEXT (@Take) ROWS ONLY
Untuk memilih baris 1000-1100 daripada jadual tertentu, anda akan menggunakan pertanyaan berikut:
SELECT * FROM Sales.SalesOrderHeader ORDER BY OrderDate OFFSET 1000 ROWS FETCH NEXT 100 ROWS ONLY
Pertanyaan ini akan melaksanakan langkah berikut:
Penyelesaian ini jauh lebih cekap daripada melakukan operasi yang sama dalam ingatan, kerana ia mengelakkan keperluan untuk memilih semua baris, hanya untuk membuang 1000 pertama dan pilih 100 seterusnya secara manual.
Atas ialah kandungan terperinci Adakah Terdapat SQL Langsung yang Setara dengan Skip() dan Take() LINQ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!