- Back to Home »
- database , mysql , phpmyadmin »
- วิธีการง่ายๆกับการสร้าง View ใน SQL ( Sql Create View )
Posted by : caeruz
วันอาทิตย์ที่ 17 มีนาคม พ.ศ. 2556
เชื่อว่าส่วนใหญ่ใครหลายๆ คนก็คงรู้จัก MySql กับการสร้าง view และการเรียกใช้งาน view กันอยู่แล้วแต่ก็ยังคงมีบางส่วนที่ยังไม่รู้จัก view ,วิธีการสร้าง view ภายใน SQL ,รวมถึงประโยชน์ของ view ที่เรา จะสามารถนำมาประยุกต์ใช้ร่วมกับงานของเรา View ใน MySQL View เปรียบเสมือน Table จำลองที่ผู้ใช้งานสร้างขึ้นมาเพื่อให้เห็นเฉพาะมุมมองของข้อมูลที่ต้องการ ใช้งาน ซึ่งข้อมูลอาจมาจาก ตาราง 1 ตาราง หรือ มาจากการ join กันของหลายตารางก็ได้ โดยส่วนใหญ่ เราจะใช้งาน view ก็ต่อเมื่อ มีการเรียกใช้ข้อมูลนั้นซ้ำๆเพื่อประหยัดเวลาในการเขียนคำสั่ง SQL เราเรียก ตารางข้อมูลประเภทนี้ว่า “ตารางเสมือน”
แล้วเราสามารถ สร้าง 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 มาสร้างวิว