Rumah >pangkalan data >tutorial mysql >Mengapa Menggunakan Titik Bertitik Sebelum Ungkapan Jadual Biasa (CTE) dalam Pelayan SQL?
Koma bertitik dalam SQL Server Common Table Expressions (CTEs)
Dalam SQL Server, Common Table Expressions (CTEs) selalunya menyertakan koma bertitik di hadapan daripada pernyataan itu, seperti yang digambarkan di bawah:
;WITH OrderedOrders AS ( SELECT SalesOrderID, OrderDate, ROW_NUMBER() OVER (ORDER BY OrderDate) AS 'RowNumber' FROM Sales.SalesOrderHeader ) SELECT * FROM OrderedOrders WHERE RowNumber BETWEEN 50 AND 60
Tujuan koma bertitik
Koma bernoktah mempunyai dua tujuan:
Mengelakkan Kesamaran: WITH juga boleh digunakan dalam konteks lain, seperti :
Dalam konteks CTE, adalah disyorkan untuk menggunakan ;WITH to mengelakkan kemungkinan konflik. Jika CTE didahului dengan pernyataan yang tidak berakhir dengan koma bertitik, secara tidak sengaja menggunakan WITH sebagai sebahagian daripada pernyataan itu boleh membawa kepada tingkah laku yang tidak dijangka.
Contoh
Pertimbangkan pernyataan berikut:
DECLARE @foo int; WITH OrderedOrders AS ( SELECT SalesOrderID, OrderDate, ...;
Pernyataan ini bersamaan kepada:
DECLARE @foo int; ;WITH OrderedOrders AS ( SELECT SalesOrderID, OrderDate, ...;
Kesimpulan
Menggunakan ;WITH sebelum pernyataan CTE menambah kejelasan dan ketekalan pada pertanyaan SQL Server. Ia membantu mengelakkan kekaburan dan memastikan bahawa kenyataan ditamatkan dengan betul, meminimumkan risiko ralat.
Atas ialah kandungan terperinci Mengapa Menggunakan Titik Bertitik Sebelum Ungkapan Jadual Biasa (CTE) dalam Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!