คำสั่ง SQL SELECT

การดึงข้อมูลโดยใช้คำสั่ง SQL Select

SQL เป็นภาษาฐานข้อมูลที่ครอบคลุม SQL ออกเสียงว่า Sequel หรือ SQL เป็นภาษาโปรแกรมคอมพิวเตอร์ที่ใช้สำหรับการสืบค้นฐานข้อมูลเชิงสัมพันธ์ตามวิธีการที่ไม่ใช่เชิงประมวล เมื่อคุณดึงข้อมูลจากฐานข้อมูลโดยใช้ SQL จะเรียกว่าการสืบค้นฐานข้อมูล

ฐานข้อมูลเชิงสัมพันธ์ถูกนำมาใช้โดยใช้ระบบจัดการฐานข้อมูลเชิงสัมพันธ์ (RDBMS) RDBMS ทำหน้าที่พื้นฐานทั้งหมดของซอฟต์แวร์ DBMS ที่กล่าวถึงข้างต้นพร้อมกับฟังก์ชันอื่น ๆ อีกมากมายที่ทำให้โมเดลเชิงสัมพันธ์เข้าใจง่ายและนำไปใช้งานได้ง่ายขึ้น ผู้ใช้ RDBMS จัดการข้อมูลผ่านการใช้ภาษาจัดการข้อมูลพิเศษ โครงสร้างฐานข้อมูลถูกกำหนดโดยใช้ภาษานิยามข้อมูล คำสั่งที่ผู้ใช้ระบบดำเนินการเพื่อจัดเก็บและดึงข้อมูลสามารถป้อนที่เทอร์มินัลที่มีอินเทอร์เฟซ RDBMS โดยพิมพ์คำสั่งหรือป้อนผ่านการใช้อินเทอร์เฟซกราฟิกบางประเภท จากนั้น DBMS จะประมวลผลคำสั่ง

ความสามารถของคำสั่ง SELECT

การดึงข้อมูลจากฐานข้อมูลทำได้โดยการใช้ SQL ที่เหมาะสมและมีประสิทธิภาพ แนวคิดสามประการจากทฤษฎีเชิงสัมพันธ์ครอบคลุมความสามารถของคำสั่ง SELECT: การฉายภาพการเลือกและการเข้าร่วม

  • การฉายภาพ: การดำเนินโครงการจะเลือกเฉพาะบางคอลัมน์ (เขตข้อมูล) จากตาราง ตารางผลลัพธ์มีชุดย่อยของคอลัมน์ที่มีอยู่และสามารถรวมอะไรก็ได้ตั้งแต่คอลัมน์เดียวไปจนถึงคอลัมน์ที่มีทั้งหมด

  • การเลือก: การดำเนินการเลือกจะเลือกชุดย่อยของแถว (ระเบียน) ในตาราง (ความสัมพันธ์) ที่เป็นไปตามเงื่อนไขการเลือก ความสามารถในการเลือกแถวจากชุดผลลัพธ์ที่ไม่สมบูรณ์เรียกว่าการเลือก มันเกี่ยวข้องกับการกรองตามเงื่อนไขและการจัดเตรียมข้อมูล ชุดย่อยสามารถมีตั้งแต่ไม่มีแถวถ้าไม่มีแถวใดที่ตรงตามเงื่อนไขการเลือกไปจนถึงแถวทั้งหมดในตาราง

  • การเข้าร่วม: การดำเนินการรวมรวมข้อมูลจากตารางสองตารางขึ้นไปโดยยึดตามค่าคอลัมน์ทั่วไปอย่างน้อยหนึ่งค่า การดำเนินการรวมช่วยให้ผู้ใช้ระบบสารสนเทศสามารถประมวลผลความสัมพันธ์ที่มีอยู่ระหว่างตาราง การดำเนินการรวมมีประสิทธิภาพมากเนื่องจากช่วยให้ผู้ใช้ระบบสามารถตรวจสอบความสัมพันธ์ระหว่างองค์ประกอบข้อมูลที่อาจไม่ได้คาดการณ์ไว้ในขณะที่ออกแบบฐานข้อมูล

พิจารณาโครงสร้างตารางข้างต้น การเรียกชื่อ first_name, department_id และเงินเดือนสำหรับพนักงานคนเดียวจากตาราง EMPLOYEES คือ Projection การเรียกรายละเอียดพนักงานที่เงินเดือนน้อยกว่า 5,000 จากตาราง EMPLOYEES คือ Selection การเรียกชื่อของพนักงานชื่อแผนกโดยการเข้าร่วม EMPLOYEES และ DEPARTMENTS กำลังเข้าร่วม

คำสั่งพื้นฐาน SELECT

ไวยากรณ์พื้นฐานสำหรับคำสั่ง SELECT แสดงอยู่ด้านล่าง

SELECT  [DISTINCT | ALL] {* | select_list}
FROM {table_name [alias] | view_name} 
    [{table_name [alias]  | view_name}]...  
[WHERE  condition]
[GROUP BY  condition_list]
[HAVING  condition]
[ORDER BY  {column_name | column_#  [ ASC | DESC ] } ...

ส่วนคำสั่ง SELECT เป็นข้อบังคับและดำเนินการโครงการเชิงสัมพันธ์

คำสั่ง FROM ยังบังคับ ระบุตารางอย่างน้อยหนึ่งตารางและ / หรือมุมมองที่จะดึงข้อมูลคอลัมน์ที่แสดงในตารางผลลัพธ์

คำสั่ง WHERE เป็นทางเลือกและดำเนินการเลือกเชิงสัมพันธ์ ระบุว่าจะเลือกแถวใด

GROUP BY clause เป็นทางเลือก จัดระเบียบข้อมูลเป็นกลุ่มตามชื่อคอลัมน์อย่างน้อยหนึ่งชื่อที่แสดงอยู่ในคำสั่ง SELECT

ส่วนคำสั่ง HAVING ที่เป็นทางเลือกกำหนดเงื่อนไขเกี่ยวกับกลุ่มที่จะรวมไว้ในตารางผลลัพธ์ กลุ่มถูกระบุโดยคำสั่ง GROUP BY

คำสั่ง ORDER BY เป็นทางเลือก จัดเรียงผลลัพธ์การสืบค้นตามคอลัมน์อย่างน้อยหนึ่งคอลัมน์ตามลำดับจากน้อยไปมากหรือมากไปหาน้อย

นิพจน์เลขคณิตและค่า NULL ในคำสั่ง SELECT

นิพจน์เลขคณิตสามารถสร้างได้โดยใช้ชื่อคอลัมน์ตัวดำเนินการและค่าคงที่เพื่อฝังนิพจน์ในคำสั่ง SELECT ตัวดำเนินการที่ใช้กับคอลัมน์ขึ้นอยู่กับชนิดข้อมูลของคอลัมน์ ตัวอย่างเช่นตัวดำเนินการทางคณิตศาสตร์จะไม่พอดีกับค่าลิเทอรัลของอักขระ ตัวอย่างเช่น,

SELECT employee_id, sal * 12 ANNUAL_SAL
FROM employees;

ข้อความค้นหาข้างต้นประกอบด้วยนิพจน์เลขคณิต (sal * 12) เพื่อคำนวณเงินเดือนประจำปีของพนักงานแต่ละคน

ตัวดำเนินการเลขคณิต

ตัวดำเนินการดำเนินการกับคอลัมน์ (เรียกว่าตัวถูกดำเนินการ) เพื่อให้ได้ผลลัพธ์ที่แตกต่างกัน ในกรณีที่มีตัวดำเนินการหลายตัวในนิพจน์ลำดับของการอพยพจะถูกกำหนดโดยลำดับความสำคัญของตัวดำเนินการ นี่คือกฎพื้นฐานของลำดับความสำคัญ -

  • การคูณและการหารเกิดขึ้นก่อนการบวกและการลบ

  • ตัวดำเนินการที่มีลำดับความสำคัญเดียวกันจะได้รับการประเมินจากซ้ายไปขวา

  • ใช้ paretheses เพื่อแทนที่พฤติกรรมเริ่มต้นของตัวดำเนินการ

ตารางด้านล่างแสดงลำดับความสำคัญของตัวดำเนินการในกรณีเช่นนี้ การดำเนินการสัญลักษณ์ตัวดำเนินการระดับลำดับความสำคัญ

Description   Operator	Precedence	   
Addition	+	Lowest	   
Subtraction	-	Lowest	   
Multiplication	*	Medium	   
Division	/	Medium	   
Brackets	( )	Highest

ตรวจสอบข้อความค้นหาด้านล่าง (a) (b) และ (c)

  • SQL> SELECT 2*35 FROM DUAL;
  • SQL> SELECT salary + 1500 FROM employees;
  • SQL> SELECT first_name, salary, salary + (commission_pct* salary) FROM employees;

แบบสอบถาม (a) คูณสองตัวเลขในขณะที่ (b) แสดงการเพิ่ม $ 1,500 ให้กับเงินเดือนของพนักงานทุกคน แบบสอบถาม (c) แสดงการเพิ่มองค์ประกอบค่าคอมมิชชั่นในเงินเดือนของพนักงาน ตามลำดับค่าคอมมิชชั่นแรกจะคำนวณจากเงินเดือนจากนั้นจึงเพิ่มเข้าไปในเงินเดือน

ชื่อแทนคอลัมน์

นามแฝงใช้เพื่อเปลี่ยนชื่อคอลัมน์หรือนิพจน์ระหว่างการแสดงผล นามแฝงของคอลัมน์หรือนิพจน์ปรากฏเป็นส่วนหัวในผลลัพธ์ของแบบสอบถาม มีประโยชน์ในการระบุส่วนหัวที่มีความหมายไปยังนิพจน์แบบยาวในคิวรี SELECT โดยค่าเริ่มต้นนามแฝงจะปรากฏเป็นตัวพิมพ์ใหญ่ในผลลัพธ์แบบสอบถามโดยไม่มีช่องว่าง ในการลบล้างพฤติกรรมนี้นามแฝงต้องอยู่ภายในเครื่องหมายคำพูดคู่เพื่อรักษากรณีและช่องว่างในชื่อนามแฝง

SELECT price * 2 as DOUBLE_PRICE, price * 10 "Double Price"
FROM products;

DOUBLE_PRICE	Double Price
------------	------------
39.9			39.9
60			60
51.98			51.98

ตัวดำเนินการเชื่อมต่อ

สามารถใช้ตัวดำเนินการเชื่อมต่อเพื่อรวมค่าสตริงหรือนิพจน์สองค่าในคิวรี SELECT สัญลักษณ์แถบแนวตั้งคู่ใช้เป็นตัวดำเนินการต่อสตริง ใช้ได้เฉพาะกับค่าคอลัมน์อักขระและสตริงที่ทำให้เกิดนิพจน์อักขระใหม่ ตัวอย่าง

SQL> SELECT 'ORACLE'||' CERTIFICATION' FROM dual;

ข้อความค้นหาด้านบนแสดงการเรียงต่อกันของค่าตัวอักษรสองค่า

ตัวอักษร

ค่าฮาร์ดโค้ดใด ๆ ซึ่งไม่ได้เก็บไว้ในฐานข้อมูลในส่วนคำสั่ง SELECT จะเรียกว่าตัวอักษร อาจเป็นตัวเลขอักขระหรือค่าวันที่ ค่าอักขระและวันที่ต้องอยู่ในเครื่องหมายคำพูด พิจารณาคำสั่ง SQL ด้านล่างตัวอย่างของการใช้ตัวอักษรของชนิดข้อมูลที่แตกต่างกันในแบบสอบถาม SQL

ข้อความค้นหาด้านล่างใช้ตัวอักษรสองตัวเพื่อรวมเข้าด้วยกัน

SQL> SELECT 'ORACLE'||' CERTIFICATION' FROM DUAL

ข้อความค้นหาด้านล่างใช้ตัวอักษรเพื่อพิมพ์เงินเดือนของพนักงาน

SQL> SELECT first_name ||'earns'|| salary||' as of '|||sysdate
FROM employees

ตัวดำเนินการใบเสนอราคา

ตัวดำเนินการใบเสนอราคาใช้เพื่อระบุตัวคั่นเครื่องหมายคำพูดของคุณเอง คุณสามารถเลือกตัวคั่นที่สะดวกโดยขึ้นอยู่กับข้อมูล

SELECT 	department_name|| ' Department' ||q'['s Manager Id: ]'|| manager_id
FROM departments;

NULL

ถ้าคอลัมน์ไม่มีค่าที่แน่นอนจะถือว่าเป็น NULL ค่า NULL หมายถึงไม่ทราบหรือไม่พร้อมใช้งาน ไม่ใช่ศูนย์สำหรับค่าตัวเลขไม่ใช่ช่องว่างสำหรับค่าอักขระ

คอลัมน์ที่มีค่า NULL สามารถเลือกได้ในแบบสอบถาม SELECT และสามารถเป็นส่วนหนึ่งของนิพจน์เลขคณิต นิพจน์ทางคณิตศาสตร์ใด ๆ ที่ใช้ค่า NULL จะให้ผลลัพธ์เป็น NULL ด้วยเหตุนี้คอลัมน์ที่มีค่า NULL จึงต้องได้รับการจัดการที่แตกต่างกันโดยการระบุค่าทางเลือกของพวกเขาโดยใช้ฟังก์ชันที่จัดให้โดย Oracle เช่น NVL หรือ NULLIF

SQL> SELECT NULL + 1000 NUM 
FROM DUAL;

NUM
--------

DISTINCT คำหลัก

หากคาดว่าข้อมูลจะมีผลลัพธ์ที่ซ้ำกันให้ใช้คีย์เวิร์ด DISTINCT เพื่อกำจัดรายการที่ซ้ำกันและแสดงเฉพาะผลลัพธ์ที่ไม่ซ้ำกันในเอาต์พุตเคียวรี เฉพาะคอลัมน์ที่เลือกเท่านั้นที่ได้รับการตรวจสอบความถูกต้องสำหรับการทำซ้ำและแถวจะถูกตัดออกจากผลลัพธ์แบบสอบถาม หากต้องการสังเกตคีย์เวิร์ด DISTINCT ต้องปรากฏหลังอนุประโยค SELECT

แบบสอบถามง่ายๆด้านล่างแสดงให้เห็นถึงการใช้ DISTINCT เพื่อแสดงรหัสแผนกที่ไม่ซ้ำกันจากตาราง EMPLOYEES

SQL> SELECT DISTINCT DEPARTMENT_ID 
FROM employees;

DEPARTMENT_ID
---------------
10
20
30
40

คำสั่ง DESCRIBE

ข้อมูลเมตาที่มีโครงสร้างของตารางสามารถหาได้จากการสอบถามฐานข้อมูลสำหรับรายการคอลัมน์ที่ประกอบขึ้นด้วยคำสั่ง DESCRIBE จะแสดงรายการชื่อคอลัมน์ที่ใช้คุณสมบัติว่างและชนิดข้อมูล

Syntax:

DESC[RIBE] [SCHEMA].object name

ตัวอย่างเช่น,

DESC EMPLOYEE

จะแสดงโครงสร้างตาราง EMPLOYEE เช่นคอลัมน์ประเภทข้อมูลความแม่นยำและคุณสมบัติที่เป็นโมฆะ