Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 108,061

HOME > PHP > PHP Forum > ขอคำแนะนำการ Select 3 ตาราง ที่อีกตารางไม่มีข้อมูลในการบันทึก แต่ต้องการแสดงข้อมูลอีกตารางด้วย



 

ขอคำแนะนำการ Select 3 ตาราง ที่อีกตารางไม่มีข้อมูลในการบันทึก แต่ต้องการแสดงข้อมูลอีกตารางด้วย

 



Topic : 134021



โพสกระทู้ ( 30 )
บทความ ( 0 )



สถานะออฟไลน์




ความต้องการคือ จะให้แสดงข้อมูลงานที่ถูกกำหนดขึ้นที่ตรงกับระดับ พนง. (USER) ที่กำหนดเป็นไอดี ใน ตาราง works_detailss
และ แสดงข้อมูลการส่งงานว่าส่งงานหรือยัง โดยเก็บข้อมูลส่งงานในตาราง sentjobs_worksheets เมื่อส่งงาน

ข้อมูลตาราง

ตาราง works_detailss
id
name_wosheett
id_workjobss
id_level_workjobss

ตาราง sentjobs_worksheets
id_nosheets
idg_workss (เก็บไอดีงาน)
id_level_sentwo
text_sents_ws
status_checksheet (เก็บสถานะตรวจงงาน)


และตาราง staff_user (USER) เก็บข้อมูลพนักงาน


ตย. ที่จะให้ระบบแสดง คือ

รหัสระดับ พนง. รหัสงาน ชื่องาน สถานะการส่งงาน

โค้ดตามด้านล่างครับ


Code (PHP)
              <table class="table">
               <thead>
                  <tr>
                    <hr>
                    <th>ระดับ พนง.</th>
                    <th>รหัสงาน</th>
                    <th>ชื่องาน</th>
                    <th>สถานะตรวจ</th>
                     <th>ลิงค์(คลิก)</th>
                  </tr>
                </thead>
               <tbody>  
                
    <?php
    include('../inc/connect.php');
    $objCon->set_charset("utf8");

    $strSQL8 = "SELECT *
    FROM staff_user, works_detailss , sentjobs_worksheets 
    WHERE stafft_user.id_staff = '".$_SESSION['id_staff']."'
	AND works_detailss.id_level_workjobss = staff_user.id_level
	AND works_detailss.category_staff = 'SHL'
	GROUP BY works_detailss.id_workjobss DESC ";
    $objQuery8 = mysqli_query($objCon,$strSQL8) or die ;
    while($objResult8=mysqli_fetch_array($objQuery8))
         {
?>
     
                  <tr>
 
                    <td><font color="#990033"><b><?php echo $objResult8['id_level_workjobss'];?></b></font></td>
                   
                    <td><b><font color="#000000"><?php echo $objResult8['id_workjobss'];?></b></font></td>
                    
                    <td><?php echo $objResult8['name_wosheett'];?></td>
                    
                    <td>
                    <?php
					$B_1 = '<a class="btn btn-success">ส่งคำตอบแล้ว</a> | ดูคำตอบ';
					$B_2 = '<a class="btn btn-danger" href="works_sheets.php?id_workjobss='.$objResult8["id_workjobss"].'">ตอบคำถาม</a>';	
                    $status_ch = $objResult8['id_workjobss'];
                    if ($objResult8['idg_workss'] == $status_ch && $_SESSION['id_staff'] == $objResult8['idstaff_sentsheet'] ) {
                        echo $B_1;
                        } else {
                        echo $B_2;
                        }
                    ?> 
                    </td>
                        </tr>
                         </tbody>	
                           <?php } ?>	  
                             </table>
                             



สิ่งที่เกิดขึ้นเมื่อผมใส่ FROM sentjobs_worksheets เข้าไปและไม่ได้กำหนดเงื่อนไขอ้างอิง sentjobs_worksheets เพราะถ้าผมใส่เงื่อนไขไป ถ้าในตาราง sentjobs_worksheets พนักนักงานไม่ได้ส่งงานอะไรเลย ผลที่มันแสดงคือ "ไม่มีข้อมูลใดๆแสดงเลย" ถึงแม้ว่า ข้อมูลระดับของ พนง. ในตาราง works_detailss จะต้องกับระดับสมาชิก

แต่ถ้าไม่ใส่ FROM sentjobs_worksheets เข้าไป ก็ไม่สามารถดึงสถานะการส่งในตาราง sentjobs_worksheets มาเปรียบเทียบเพื่อแจ้งสถานะการส่งงานได้ ถูกต้องไหมครับ

ขอคำแนะนำพี่ๆหน่อยว่าผมควรเขียนโค้ดแบบไหน ตรงไหนต้องแก้บ้างครับ



Tag : PHP, MySQL







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2019-08-13 20:39:05 By : ices View : 87 Reply : 2
 

 

No. 1



โพสกระทู้ ( 8,111 )
บทความ ( 2 )



สถานะออฟไลน์


เปลี่ยนจาการใช้ ชื่อตาราง คอมม่า ชื่อตาราง ไปใช้
left join

การใช้ คอมม่า where คือการ inner join
ต้องมีเหมือนกัน ทุกตาราง






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2019-08-13 20:52:00 By : Chaidhanan
 


 

No. 2



โพสกระทู้ ( 30 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 1 เขียนโดย : Chaidhanan เมื่อวันที่ 2019-08-13 20:52:00
รายละเอียดของการตอบ ::
ขอบคุณมากๆครับผม สำเร็จแล้ว## ได้ความรู้เยอะเลยครับ เมื่อก่อนเคยคิดว่ามันไม่ง่าย จนได้ทำกับตัวเอง และมันก็สำเร็จ เรียนรู้ต่อไปครับ ขอบคุณมากๆครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2019-08-13 21:56:48 By : ices
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ขอคำแนะนำการ Select 3 ตาราง ที่อีกตารางไม่มีข้อมูลในการบันทึก แต่ต้องการแสดงข้อมูลอีกตารางด้วย
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: Voake, Comcube, รับทำเว็บไซต์ รับเขียนโปรแกรม

Load balance : Server 00
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2020 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่