ไวยากรณ์ของฟังก์ชัน
ด้านล่างคือไวยากรณ์ของฟังก์ชัน last_value
LAST_VALUE ( [ scalar_expression ] ) [ IGNORE NULLS | เคารพเป็นโมฆะ ]มากกว่า ( [ partition_by_clause ] order_by_clause [ rows_range_clause ] )
อาร์กิวเมนต์ของฟังก์ชันคือ:
- scalar_expression – เป็นการกำหนดค่าที่จะส่งคืน ซึ่งอาจเป็นคอลัมน์ที่มีอยู่ ข้อความค้นหาย่อย หรือนิพจน์ที่ส่งกลับเป็นค่าเดียว
- IGNORE NULLS – สิ่งนี้ทำให้ฟังก์ชันละเว้นค่า Null ในชุดที่กำหนดเมื่อกำหนดค่าสุดท้ายบนพาร์ติชัน
- RESPECT NULL – ตรงข้ามกับ IGNORE NULL clause บังคับให้ฟังก์ชันพิจารณาค่า NULL เมื่อกำหนดค่าสุดท้ายบนพาร์ติชัน
- PARTITION BY – การแบ่งแถวของผลลัพธ์ที่กำหนดออกเป็นพาร์ติชันต่างๆ จากนั้นจึงใช้ฟังก์ชัน last_value กับพาร์ติชันเหล่านี้ หากไม่มีส่วนคำสั่ง partition_by ฟังก์ชันจะถือว่าชุดผลลัพธ์เป็นกลุ่มเดียว
- ORDER BY – สิ่งนี้กำหนดว่าแถวใดในพาร์ติชันที่กำหนดจะตามมา
- Rows_range – ส่วนคำสั่งนี้จำกัดแถวในพาร์ติชันที่กำหนด ทำงานโดยการตั้งค่าเริ่มต้นและสิ้นสุด
ฟังก์ชันส่งคืนชนิดของ scalar_expression ที่ระบุ
การใช้ฟังก์ชัน last_value กับชุดผลลัพธ์
สมมติว่าเรามีตารางที่แสดง:
เราสามารถใช้ฟังก์ชัน last_value() กับชุดผลลัพธ์ ดังที่แสดงในตัวอย่างการสืบค้นด้านล่าง:
เลือกชื่อเซิร์ฟเวอร์,
ที่อยู่เซิฟเวอร์ ,
COMPRESSION_METHOD
SIZE_ON_DISK,
last_value(size_on_disk) มากกว่า(
ลำดับตาม size_on_disk ช่วงระหว่าง unbounded ก่อนและ unbounded following) ใหญ่ที่สุด
จาก
รายการ E;
ค่าผลลัพธ์:
การใช้ฟังก์ชัน last_value บนพาร์ติชัน
เรายังสามารถใช้ฟังก์ชัน last_value() กับพาร์ติชันได้ดังตัวอย่างด้านล่าง:
เลือกชื่อเซิร์ฟเวอร์,
ที่อยู่เซิฟเวอร์ ,
COMPRESSION_METHOD
SIZE_ON_DISK,
last_value(size_on_disk) over (พาร์ติชั่นตาม COMPRESSION_METHOD
ลำดับตาม size_on_disk ช่วงระหว่าง unbounded ก่อนและ unbounded following) ใหญ่ที่สุด
จาก
รายการ E;
ในกรณีนี้ ข้อมูลจะถูกจัดกลุ่มเป็นพาร์ติชันต่างๆ ตามวิธีการบีบอัด
ค่าที่ได้จะเป็นดังนี้:
ในตารางด้านบน เรามีห้าพาร์ติชัน โดยค่าสูงสุดในแต่ละพาร์ติชันจะแสดงในคอลัมน์ที่ใหญ่ที่สุด
บทสรุป
ในบทช่วยสอนนี้ คุณได้เรียนรู้วิธีใช้ฟังก์ชัน SQL Server last_value() เพื่อรับค่าสุดท้ายในชุดหรือพาร์ติชันที่สั่งซื้อ