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

Registered : 109,037

HOME > PHP > PHP Forum > ผมอยากถามปัญหาเกี่ยวกับเรื่อง Query กับ While loop ครับ



 

ผมอยากถามปัญหาเกี่ยวกับเรื่อง Query กับ While loop ครับ

 



Topic : 127211



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



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




พอดีผมจำทำหน้านับว่ามีจำนวนนักเรียนกี่คนที่ไม่เข้าเรียนครับ (เป็นระบบที่พัฒนาต่อจาก SMSS ของ สพฐ.) โดยที่ให้นับแยกตามวิชาครับ ทีนี้ผมลองทำดูแล้ว ผม query แยกออกเป็นสองรอบครับ รอบแรกคือ query ที่หัวตารางออกมาว่ามีวิชาอะไรบ้าง แล้วให้ while loop ไป แล้วตรงส่วนตารางนับจับนวน ก็ query อีกอันหนึ่ง ตรงตัวแปร ($sql_val) แต่พอ var_dump ออกมาแล้ว มัน query ออกมาแค่วิชาสุดท้ายของชั้นๆนั้นครับ ผมจะต้องแก้ปัญหายังไงครับ และจะคิวรี่ข้อมูลออกมายังไงครับ
โค้ดหน้านี้ครับ

Code (PHP)
<table width=100%>
<TR  bgcolor='#FFCCCC'>
	<TD width=40 align=center rowspan=2><B>ที่</B></TD>
	<TD width=100 align=center rowspan=2><B>รหัสประจำตัว</B></TD>
	<TD align=center rowspan=2><B>ชื่อ - สกุล</B></TD>
	<TD width=40 align=center rowspan=2><B>เลขที่</B></TD>
	<td align=center rowspan=2><b>ห้อง</b></td>
	<?php 

			$SQL2 = "SELECT sub_code from student_subject where std_class='$class' and room = '$room'";
			$c = $db->prepare($SQL2);
			$c->execute();
			$count_sub = $c->rowCount();
			?>
		<TD align=center colspan=32><B>รหัสวิชา</B></TD>
		<tr bgcolor='#FFCCCC'>
			<?php
			while($row = $c->fetch()){
				$sub = $row['sub_code'];
			echo "<td>$sub</td>";
			}
			 ?>
			
		</tr>
		<?php  //
	$sql=$sql." ORDER BY student_main.id  LIMIT $start,$pagelen";
	$dbquery = $db->prepare($sql);
	$dbquery->execute();
	$M=1;
		$N=(($page-1)*$pagelen)+1;
	if($count_sub !== 0){

		While ($result = $dbquery->fetch()){
			$color=(($M%2) == 0)?" class='even'":" class='odd'";
			#$color=($result[status]==0)?"  class='out'":$color;
			$room=$result['room'];
			echo"<TR $color>
				<TD align=right>$N</TD>
				<TD align=center>$result[student_id]<INPUT TYPE=hidden name=student_id[] value=$result[student_id]></TD>
				<TD><B>$result[prename] $result[name]  $result[surname]</B></TD>
						<TD align=center>$result[student_number]</TD>
				<td align=center>$room</td>";
				
			$sql_val = "SELECT * from student_inclass_main inner join student_subject on (student_inclass_main.class_now=student_subject.std_class) where month(check_date) = $_REQUEST[month] and class_now=$class and room_now=$room and student_check_year='$year_active' and student_id=$result[student_id] and sub_code='$sub'";
		
			$query_val = $db->prepare($sql_val);
			$query_val->execute();
		
			for($t=0;$t<=$count_sub;$t++){
				$Lnums[$t]=0;
			}

			while($rs = $query_val->fetch()){
				$tmp = array();
				$tmp=explode(",",$rs['check_val']);
				for($cTmp=0;$cTmp<count($tmp);$cTmp++){
					$tmpC=explode(":",$tmp[$cTmp]);
					@$Lnums[$cTmp]=($tmpC[1]!="C" && $tmpC[1]!="T")?$Lnums[$cTmp]+1:$Lnums[$cTmp]+0;

				}
			}
			for($t=0;$t<$count_sub;$t++){
				echo "<td>$Lnums[$t]</td>";

			}

		}
				
$M++;
			$N++;
		
			}
		}else{
			
		}
		echo "</table>";
 ?>
<script>
function goto_url(val){
	if(val==0){
		callfrm("?option=report_table");   // page ย้อนกลับ 
	}else if(val==1){
		 if(frm1.class_now.value == ""){
			alert("กรุณาเลือกชั้น");
		}else if(frm1.part.value == ""){
			alert("กรุณาเลือกภาคเรียน");
		}else if(frm1.month.value == ""){
			alert("กรุณาเลือกเดือน");
		}else{
			callfrm("?option=report_table&index=1");   //page ประมวลผล
		}
	}
}

</script>



ผลลัพธ์ที่ออกมาครับ

001


แต่ผลลัพธ์ที่อยากให้ออกมาเป็นลักษณะอย่างนี้ครับ

edit_

ข้อมูลตาราง SQL ในระบบนะครับ
ตาราง student_inclass_main (บันทึกการเช็คชื่อเข้าชั้นเรียน)

student_inclass_main


ตาราง student_main (บันทึกรายชื่อนักเรียน)

table_1



ตาราง student_ref (เก็บว่าในแต่ละวิชามีเรียนคาบไหนในแต่ละวันบ้าง)

table_2


ตาราง student_subject (เก็บชื่อรายวิชานั้นๆ)

table_0


ลองดูให้หน่อยนะครับ ขอบคุณมากๆครับ :)



Tag : PHP, MySQL









ประวัติการแก้ไข
2017-04-16 09:13:50
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2017-04-16 09:10:23 By : chiradet2544 View : 2719 Reply : 2
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

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

คุณจะต้อง Loop 2 ชั้นนะครับ

1. Loop จำนวนนักเรียน (แนวตั้ง)
2. Loop จำนวนวิชาของแต่ล่ะคน (แนวนอน)

แล้วดู Query ว่าแทรกเงื่อนไข =$รหัสนักเรียน และ =$รหัสวิชา ถูกต้องหรือไม่ แค่นั้นก็น่าจะได้แล้วครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-04-16 16:02:42 By : mr.win
 


 

No. 2



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



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


ตอบความคิดเห็นที่ : 1 เขียนโดย : mr.win เมื่อวันที่ 2017-04-16 16:02:42
รายละเอียดของการตอบ ::
ขอบคุณครับ ได้แล้วครับ :)

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-04-16 16:09:10 By : chiradet2544
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ผมอยากถามปัญหาเกี่ยวกับเรื่อง Query กับ While loop ครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

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