Posted by : caeruz วันอาทิตย์ที่ 17 มีนาคม พ.ศ. 2556

เชื่อว่าส่วนใหญ่ใครหลายๆ คนก็คงรู้จัก MySql กับการสร้าง view และการเรียกใช้งาน view กันอยู่แล้วแต่ก็ยังคงมีบางส่วนที่ยังไม่รู้จัก view ,วิธีการสร้าง view ภายใน SQL ,รวมถึงประโยชน์ของ view ที่เรา จะสามารถนำมาประยุกต์ใช้ร่วมกับงานของเรา View ใน MySQL View เปรียบเสมือน Table จำลองที่ผู้ใช้งานสร้างขึ้นมาเพื่อให้เห็นเฉพาะมุมมองของข้อมูลที่ต้องการ ใช้งาน ซึ่งข้อมูลอาจมาจาก ตาราง 1 ตาราง หรือ มาจากการ join กันของหลายตารางก็ได้ โดยส่วนใหญ่ เราจะใช้งาน view ก็ต่อเมื่อ มีการเรียกใช้ข้อมูลนั้นซ้ำๆเพื่อประหยัดเวลาในการเขียนคำสั่ง SQL เราเรียก ตารางข้อมูลประเภทนี้ว่า “ตารางเสมือน”

แล้วเราสามารถ สร้าง view ได้อย่างไร 

จากความสัมพันธ์ตามภาพด้านบนน่ะครับ เราสามารถรวมตาราง tb_order และ tbl_orderdetail เป็น view ได้ดังนี้

CREATE VIEW `product`.`order_detail_view` AS
SELECT tbl_order.order_id, tbl_order.order_date, tbl_order.order_time, 
tbl_orderdetail.product_id, tbl_orderdetail.qty,tbl_orderdetail.saleprice
FROM tbl_order , tbl_orderdetail
WHERE tbl_order.order_id = tbl_orderdetail.order_id;

จากตัวอย่างด้านบน เป็นการสร้าง view ชื่อว่า  order_detail_view และเราสามารถเรียกใช้งาน view ได้ดังนี้

SELECT * FROM order_detail_view

ซึ่งการเรียกใช้งานข้อมูลจากวิวนั้นเราสามารถเรียกใช้งานเหมือนกับคำสั่งการเรียกข้อมูลจากตารางข้อมูล
ทั่วไปนั้นเอง

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

-สามารถกำหนดเงื่อนไขการเรียกใช้ลงในวิวอย่างถาวร เพื่อให้ง่ายต่อผู้ใช้ 

 ประโยชน์ของวิว
 

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

- ลดคำสั่ง sql ในการเรียกใช้งานข้อมูล ทำให้ใช้งานได้สะดวกและง่ายต่อการเรียกข้อมูลมากขึ้น 

ข้อด้อยของวิว 
- ถ้าวิวสร้างมาจากตารางข้อมูลที่เชื่อมกันอย่างซับซ้อน ก็จะต้องกินเวลาในการทำงานนาน 
- สำหรับวิวที่ซับซ้อนก็จะจำกัดให้อ่านข้อมูลได้อย่างเดียว ไม่สามารถ UPDATE ข้อมูลได้ ตัวอย่างเช่น
  ข้อมูลที่ถูกเรียกโดย group by มาสร้างวิว



Leave a Reply

Subscribe to Posts | Subscribe to Comments

Categories

Popular Post

ขับเคลื่อนโดย Blogger.

- Copyright © Stimulus ♥ Hooked on Developer -Metrominimalist- Powered by Blogger - Designed by Johanes Djogan - Yahoo bot last visit powered by MyPagerank.Net -

สะพานบอทฟรี - ติดgoogleอย่างง่าย ด้วยสะพานบอท