|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
ตารางปิดงานของพนักงานวันเดือนปี จะให้โชว์ผลรวมยังไงหรอครับ |
|
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
data:image/s3,"s3://crabby-images/3b721/3b7216275514b8985f7f0c96790d976d2fff0eee" alt="ผลรวม ผลรวม"
Code (PHP)
<center><h3>ตารางวันเวลา LAY</h3></center>
<!--เริ่มต้นตาราง-->
<div class="table-responsive">
<form method="POST" action="<?php echo $_SERVER['PHP_SELF'];?>">
<table >
<tr>
<td>ระบุเดือน-ปี : </td>
<td>
<select name="txt_month">
<option value="">--------------</option>
<?php
$month = array('01' => 'มกราคม', '02' => 'กุมภาพันธ์', '03' => 'มีนาคม', '04' => 'เมษายน',
'05' => 'พฤษภาคม', '06' => 'มิถุนายน', '07' => 'กรกฎาคม', '08' => 'สิงหาคม',
'09' => 'กันยายน ', '10' => 'ตุลาคม', '11' => 'พฤศจิกายน', '12' => 'ธันวาคม');
$txtMonth = isset($_POST['txt_month']) && $_POST['txt_month'] != '' ? $_POST['txt_month'] : date('m');
foreach($month as $i=>$mName) {
$selected = '';
if($txtMonth == $i) $selected = 'selected="selected"';
echo '<option value="'.$i.'" '.$selected.'>'. $mName .'</option>'."\n";
}
?>
</select>
</td>
<td>
<select name="txt_year">
<option value="">--------------</option>
<?php
$txtYear = (isset($_POST['txt_year']) && $_POST['txt_year'] != '') ? $_POST['txt_year'] : date('Y');
$yearStart = date('Y');
$yearEnd = $txtYear-5;
for($year=$yearStart;$year > $yearEnd;$year--){
$selected = '';
if($txtYear == $year) $selected = 'selected="selected"';
echo '<option value="'.$year.'" '.$selected.'>'. ($year+543) .'</option>'."\n";
}
?>
</select>
</td>
<td><input type="submit" value="ค้นหา" /></td>
</tr>
</table>
</form>
<br>
<?php
//รับค่าตัวแปรที่ส่งมาจากแบบฟอร์ม HTML
$year = isset($_POST['txt_year']) ? mysqli_real_escape_string($con,$_POST['txt_year']) : '';
$month = isset($_POST['txt_month']) ? mysqli_real_escape_string($con,$_POST['txt_month']) : '';
if($year == '' || $month == '') exit('<p class="fail">กรุณาระบุ "เดือน-ปี" ที่ต้องการเรียกรายงาน</p>');
//ดึงข้อมูลพนักงานทั้งหมด
$allEmpData = array();
$strSQL = "SELECT * FROM user a,blockzone b
WHERE a.bz_id = b.bz_id
order by a.bz_id asc";
$qry = mysqli_query($con , $strSQL) or die('ไม่สามารถเชื่อมต่อฐานข้อมูลได้ Error : '. mysqli_error());
while($row = mysqli_fetch_assoc($qry)){
$allEmpData[$row['no_user']] = array ('empname'=> $row['user_name'],'blockzone'=>$row['bz_name']);
}
/*echo "<pre>";
print_r($allEmpData);
echo "</pre>";*/
//เรียกข้อมูลการจองของเดือนที่ต้องการ
$allReportData = array();
$strSQL = "SELECT no_user, DAY(`time`) AS time, COUNT(*) AS numBook FROM `lay` ";
$strSQL.= "WHERE `time` LIKE '$year-$month%' ";
$strSQL.= "GROUP by no_user,DAY(`time`)";
$qry = mysqli_query($con , $strSQL) or die('ไม่สามารถเชื่อมต่อฐานข้อมูลได้ Error : '. mysqli_error());
while($row = mysqli_fetch_assoc($qry)){
$allReportData[$row['no_user']][$row['time']] = $row['numBook'];
}
echo "<table class='table table-bordered table-sm' >";
echo '<tr class="table-primary">';//เปิดแถวใหม่ ตาราง HTML
echo '<th>blockzone</th>';
echo '<th>รายชื่อพนักงาน</th>';
//วันที่สุดท้ายของเดือน
$timeDate = strtotime($year.'-'.$month."-01"); //เปลี่ยนวันที่เป็น timestamp
$lastDay = date("t", $timeDate); //จำนวนวันของเดือน
//สร้างหัวตารางตั้งแต่วันที่ 1 ถึงวันที่สุดท้ายของดือน
for($day=1;$day<=$lastDay;$day++){
echo '<th>' . substr("0".$day, -2) . '</th>';
}
echo '<th>ผลรวม</th>';
echo "</tr>";
foreach($allEmpData as $noUser => $array){
$emp_name = $array['empname'];
$bz_id = $array['blockzone'];
echo '<tr>';//เปิดแถวใหม่ ตาราง HTML
echo '<td>'. $bz_id .'</td>';
echo '<td>'. $emp_name.'</td>';
//เรียกข้อมูลการจองของพนักงานแต่ละคน ในเดือนนี้
for($j=1;$j<=$lastDay;$j++){
$numBook = isset($allReportData[$noUser][$j]) ? '<div>'.$allReportData[$noUser][$j].'</div>' : 0;
echo "<td class='number'>", $numBook, "</td>";
}
echo '</tr>';//ปิดแถวตาราง HTML
}
echo "</table>";
mysqli_close($con);//ปิดการเชื่อมต่อฐานข้อมูล
?>
</div>
</div>
พอดีผมสงสัยอ่ะครับ ว่าทำไงให้ผลรวมออกมาได้ครับ
Tag : PHP, MySQL
data:image/s3,"s3://crabby-images/f1944/f19447657087fec8fe853572ff7e2abde431999d" alt=""
|
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2018-12-19 15:12:31 |
By :
ttouch |
View :
1974 |
Reply :
3 |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
Code (PHP)
<center><h3>ตารางวันเวลา LAY</h3></center>
<!--เริ่มต้นตาราง-->
<div class="table-responsive">
<form method="POST" action="<?php echo $_SERVER['PHP_SELF'];?>">
<table >
<tr>
<td>ระบุเดือน-ปี : </td>
<td>
<select name="txt_month">
<option value="">--------------</option>
<?php
$month = array('01' => 'มกราคม', '02' => 'กุมภาพันธ์', '03' => 'มีนาคม', '04' => 'เมษายน',
'05' => 'พฤษภาคม', '06' => 'มิถุนายน', '07' => 'กรกฎาคม', '08' => 'สิงหาคม',
'09' => 'กันยายน ', '10' => 'ตุลาคม', '11' => 'พฤศจิกายน', '12' => 'ธันวาคม');
$txtMonth = isset($_POST['txt_month']) && $_POST['txt_month'] != '' ? $_POST['txt_month'] : date('m');
foreach($month as $i=>$mName) {
$selected = '';
if($txtMonth == $i) $selected = 'selected="selected"';
echo '<option value="'.$i.'" '.$selected.'>'. $mName .'</option>'."\n";
}
?>
</select>
</td>
<td>
<select name="txt_year">
<option value="">--------------</option>
<?php
$txtYear = (isset($_POST['txt_year']) && $_POST['txt_year'] != '') ? $_POST['txt_year'] : date('Y');
$yearStart = date('Y');
$yearEnd = $txtYear-5;
for($year=$yearStart;$year > $yearEnd;$year--){
$selected = '';
if($txtYear == $year) $selected = 'selected="selected"';
echo '<option value="'.$year.'" '.$selected.'>'. ($year+543) .'</option>'."\n";
}
?>
</select>
</td>
<td><input type="submit" value="ค้นหา" /></td>
</tr>
</table>
</form>
<br>
<?php
//รับค่าตัวแปรที่ส่งมาจากแบบฟอร์ม HTML
$year = isset($_POST['txt_year']) ? mysqli_real_escape_string($con,$_POST['txt_year']) : '';
$month = isset($_POST['txt_month']) ? mysqli_real_escape_string($con,$_POST['txt_month']) : '';
if($year == '' || $month == '') exit('<p class="fail">กรุณาระบุ "เดือน-ปี" ที่ต้องการเรียกรายงาน</p>');
//ดึงข้อมูลพนักงานทั้งหมด
$allEmpData = array();
$strSQL = "SELECT * FROM user a,blockzone b
WHERE a.bz_id = b.bz_id
order by a.bz_id asc";
$qry = mysqli_query($con , $strSQL) or die('ไม่สามารถเชื่อมต่อฐานข้อมูลได้ Error : '. mysqli_error());
while($row = mysqli_fetch_assoc($qry)){
$allEmpData[$row['no_user']] = array ('empname'=> $row['user_name'],'blockzone'=>$row['bz_name']);
}
/*echo "<pre>";
print_r($allEmpData);
echo "</pre>";*/
//เรียกข้อมูลการจองของเดือนที่ต้องการ
$allReportData = array();
$strSQL = "SELECT no_user, DAY(`time`) AS time, COUNT(*) AS numBook FROM `lay` ";
$strSQL.= "WHERE `time` LIKE '$year-$month%' ";
$strSQL.= "GROUP by no_user,DAY(`time`)";
$qry = mysqli_query($con , $strSQL) or die('ไม่สามารถเชื่อมต่อฐานข้อมูลได้ Error : '. mysqli_error());
while($row = mysqli_fetch_assoc($qry)){
$allReportData[$row['no_user']][$row['time']] = $row['numBook'];
}
echo "<table class='table table-bordered table-sm' >";
echo '<tr class="table-primary">';//เปิดแถวใหม่ ตาราง HTML
echo '<th>blockzone</th>';
echo '<th>รายชื่อพนักงาน</th>';
//วันที่สุดท้ายของเดือน
$timeDate = strtotime($year.'-'.$month."-01"); //เปลี่ยนวันที่เป็น timestamp
$lastDay = date("t", $timeDate); //จำนวนวันของเดือน
//สร้างหัวตารางตั้งแต่วันที่ 1 ถึงวันที่สุดท้ายของดือน
for($day=1;$day<=$lastDay;$day++){
echo '<th>' . substr("0".$day, -2) . '</th>';
}
echo '<th>ผลรวม</th>';
echo "</tr>";
foreach($allEmpData as $noUser => $array){
$emp_name = $array['empname'];
$bz_id = $array['blockzone'];
echo '<tr>';//เปิดแถวใหม่ ตาราง HTML
echo '<td>'. $bz_id .'</td>';
echo '<td>'. $emp_name.'</td>';
//เรียกข้อมูลการจองของพนักงานแต่ละคน ในเดือนนี้
$sumBook = 0;
for($j=1;$j<=$lastDay;$j++){
$numBook = isset($allReportData[$noUser][$j]) ? '<div>'.$allReportData[$noUser][$j].'</div>' : 0;
echo "<td class='number'>", $numBook, "</td>";
$sumBook += @$allReportData[$noUser][$j];
}
echo "<td>", $sumBook, "</td>";
echo '</tr>';//ปิดแถวตาราง HTML
}
echo "</table>";
mysqli_close($con);//ปิดการเชื่อมต่อฐานข้อมูล
?>
</div>
</div>
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2018-12-19 17:38:15 |
By :
Jatmentz |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/f3b89/f3b89ccde25850c65b928bee7cddda844ab028bb" alt=""
|
Load balance : Server 03
|