JOIN TABLE แบบ Left Outer Join


SQL Knowledge ทั้ง sql มาตรฐาน หลักการออกแบบฐานข้อมูล ความสัมพันธ์ของ ตาราง Mysql , PGSQL, Oracle, MSSQL

Moderators: mindphp, ผู้ดูแลกระดาน

M013
PHP Super Hero Member
PHP Super Hero Member
Posts: 829
Joined: 22/04/2010 12:02 pm

JOIN TABLE แบบ Left Outer Join

Post by M013 » 16/08/2013 5:53 pm

JOIN TABLE แบบ Left Outer Join
เป็นการ Join Table โดยยึดตารางทางซ้ายมือเป็นหลักดังภาพที่ 1.1
JOIN TABLE แบบ Left Outer Join Left_outer_join.jpg
ภาพที่ 1.1 ลักษณะการ Join Table แบบ Left Outer Join
Left_outer_join.jpg (31.9 KiB) Viewed 2454 times
รูปแบบการใช้งาน

Code: Select all

SELECT ชื่อคอลัมน์1, ชื่อคอลัมน์2, ชื่อคอลัมน์3, ...
FROM ชื่อตาราง1
LEFT OUTER JOIN ชื่อตาราง2
ON ชื่อตาราง1.ชื่อคอลัมน์=ชื่อตาราง2.ชื่อคอลัมน์;
ตัวอย่างการใช้งาน
JOIN TABLE แบบ Left Outer Join table_cusANDorde_norelation.jpg
ภาพที่ 1.2 ตารางข้อมูลลูกค้า เเละ ตารางข้อมูลการสั่งสินค้า
table_cusANDorde_norelation.jpg (151.18 KiB) Viewed 2447 times
>>ต้องการทราบชื่อลูกค้า เละ รหัสการสั่งซื้อสินค้า

Code: Select all

SELECT Customers.cus_name, Order_product.order_id
FROM Customer
LEFT OUTER JOIN Order_product
ON Customer.cus_id=Order_product.cus_id
ORDER BY Customers.cus_name;
การเเสดงผล
JOIN TABLE แบบ Left Outer Join output_Left_outer_join.jpg
ภาพที่ 1.3 จากการใช้คำสั่งจาก Code ข้างต้นจะเเสดงผลออกมาดังภาพ
output_Left_outer_join.jpg (40.85 KiB) Viewed 2454 times


User avatar
mindphp
ผู้ดูแลระบบ MindPHP
ผู้ดูแลระบบ MindPHP
Posts: 22635
Joined: 22/09/2008 6:18 pm
Contact:

Re: JOIN TABLE แบบ Left Outer Join

Post by mindphp » 19/07/2014 6:35 pm

ตัวอย่างการเขียนคำสั่ง Left Join ใน Mysql
ยกตัวอย่าง ความสัมพันธ์ของตาราง member กับ member_regis_ip
เป็นแบบ One2One
สองคำสั่งนี้จะได้ค่าต่างกัน ตามข้อมูล
เช่นถ้าเขียนแบบแรก จะยึดตาราง member_regis_ip เป็นหลัก ถ้าไม่มี mem_id ในตาราง member_regis_ip เวลารันคำสั่งก็จะไม่ได้ข้อมูลออกมา (0 record)

แบบที่สอง จะยึดตาราง member เป็นหลัก หมายความว่าถ้าไม่มีข้อมูลในตาราง member ผลที่ได้ก็จะไม่ได้ข้อมูลออกมา แต่ถ้ามี record ในตาราง member แต่ไม่มี record ในตาราง member_regis_ip ผลจากการ query ก็ยังได้ record ออกมาแสดง แต่จะขาด Field ip ไป (ได้ชื่อ field แต่ค่าเป็นค่าว่าง)

Code: Select all

            $query = "SELECT m.*,  c.ip 
                             FROM member_regis_ip c
                                LEFT JOIN  member AS m  ON c.mem_id=m.mem_id 
                            WHERE c.mem_id=" .$mem_id ." ";
                            
            $query = "SELECT m.*,  c.ip 
                             FROM member m
                                LEFT JOIN  member_regis_ip AS c  ON c.mem_id=m.mem_id 
                            WHERE m.mem_id=" .$mem_id ." ";                            
 
ติดตาม VDO: http://www.youtube.com/c/MindphpVideoman
ติดตาม FB: https://www.facebook.com/pages/MindphpC ... 9517401606
หมวดแชร์ความรู้: https://www.mindphp.com/forums/viewforum.php?f=29
รับอบรม และพัฒนาระบบ: https://www.mindphp.com/forums/viewtopic.php?f=6&t=2042

Post Reply

Return to “SQL Knowledge”

Users browsing this forum: No registered users and 3 guests