|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
PHP : รอกวนขอคำเเนะนำถ้าต้องการนำข้อมูลใน DB มาเเสดงเป็น Checkbox โดย Group ตามเเผนกให้เเสดงผลตามรูปจะมีวิธีเขียนอย่างไรครับ |
|
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="" |
|
แบบนี้ใช่ไหมครับ ลองดูแบบ loop 2 ชั้นนะครับ อาจจะตอบโจทย์ท่านไม่ได้ แต่ลองเอาไปปรับแก้ดูครับ
data:image/s3,"s3://crabby-images/53fc4/53fc41c74ad3d009384f6cb8a1065e950d1b13ac" alt="ตาราง ตาราง"
ผมทำตารางง่ายๆให้ดูเป็นตัวอย่าง 3 ตารางดังนี้ นะครับ
1.ตาราง department เก็บฝ่ายหรือหน่วยงานของคุณนั่นแหละ
data:image/s3,"s3://crabby-images/31bf2/31bf208857ee7cb1896f4f10d49d6ece7499074d" alt="dep_table dep_table"
Code (SQL)
-- ----------------------------
-- Table structure for department
-- ----------------------------
DROP TABLE IF EXISTS `department`;
CREATE TABLE `department` (
`dep_id` varchar(4) NOT NULL,
`dep_name` varchar(100) DEFAULT NULL,
PRIMARY KEY (`dep_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of department
-- ----------------------------
INSERT INTO `department` VALUES ('1001', 'หน่วยงานที่ 1');
INSERT INTO `department` VALUES ('1002', 'หน่วยงานที่ 2');
INSERT INTO `department` VALUES ('1003', 'หน่วยงานที่ 3');
INSERT INTO `department` VALUES ('1004', 'หน่วยงานที่ 4');
INSERT INTO `department` VALUES ('1005', 'หน่วยงานที่ 5');
INSERT INTO `department` VALUES ('1006', 'หน่วยงานที่ 6');
2.ตาราง staff เก็บรายชื่อพนักงาน
data:image/s3,"s3://crabby-images/22b88/22b881e733b7b942458113f421f5c9b60d2a28e8" alt="staff_table staff_table"
Code (SQL)
-- ----------------------------
-- Table structure for staff
-- ----------------------------
DROP TABLE IF EXISTS `staff`;
CREATE TABLE `staff` (
`staff_id` varchar(4) NOT NULL,
`staff_name` varchar(100) DEFAULT NULL,
PRIMARY KEY (`staff_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of staff
-- ----------------------------
INSERT INTO `staff` VALUES ('S001', 'นาย A');
INSERT INTO `staff` VALUES ('S002', 'นาย B');
INSERT INTO `staff` VALUES ('S003', 'นาย C');
INSERT INTO `staff` VALUES ('S004', 'นาย D');
INSERT INTO `staff` VALUES ('S005', 'นาย E');
INSERT INTO `staff` VALUES ('S006', 'นาย F');
INSERT INTO `staff` VALUES ('S007', 'นาย G');
INSERT INTO `staff` VALUES ('S008', 'นาย H');
INSERT INTO `staff` VALUES ('S009', 'นาย I');
INSERT INTO `staff` VALUES ('S010', 'นาย J');
INSERT INTO `staff` VALUES ('S011', 'นาย K');
INSERT INTO `staff` VALUES ('S012', 'นาย L');
INSERT INTO `staff` VALUES ('S013', 'นาย M');
INSERT INTO `staff` VALUES ('S014', 'นาย N');
INSERT INTO `staff` VALUES ('S015', 'นาย O');
INSERT INTO `staff` VALUES ('S016', 'นาย P');
INSERT INTO `staff` VALUES ('S017', 'นาย Q');
INSERT INTO `staff` VALUES ('S018', 'นาย R');
INSERT INTO `staff` VALUES ('S019', 'นาย S');
INSERT INTO `staff` VALUES ('S020', 'นาย T');
INSERT INTO `staff` VALUES ('S021', 'นาย U');
INSERT INTO `staff` VALUES ('S022', 'นาย V');
INSERT INTO `staff` VALUES ('S023', 'นาย W');
INSERT INTO `staff` VALUES ('S024', 'นาย X');
INSERT INTO `staff` VALUES ('S025', 'นาย Y');
INSERT INTO `staff` VALUES ('S026', 'นาย Z');
3.ตาราง staff_dep ใช้เก็บว่าพนักงานคนไหนอยู่หน่วยงานไหนบ้าง (ถ้าใส่ฟิวด์ dep_id ไปเลยในตาราง staff จะทำให้พนักงาน 1 คนอยู่ได้ 1 หน่วยงานเท่านั้น จึงเกิดตารางนี้ขึ้นมาครับ)
data:image/s3,"s3://crabby-images/2c0cc/2c0cc121989796d3ec459c6fa5b6dc2786fb9fe3" alt="staff_dep_table staff_dep_table"
-- ----------------------------
-- Table structure for staff_dep
-- ----------------------------
DROP TABLE IF EXISTS `staff_dep`;
CREATE TABLE `staff_dep` (
`staff_id` varchar(4) NOT NULL,
`dep_id` varchar(4) NOT NULL,
PRIMARY KEY (`staff_id`,`dep_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of staff_dep
-- ----------------------------
INSERT INTO `staff_dep` VALUES ('S001', '1004');
INSERT INTO `staff_dep` VALUES ('S002', '1002');
INSERT INTO `staff_dep` VALUES ('S003', '1006');
INSERT INTO `staff_dep` VALUES ('S004', '1003');
INSERT INTO `staff_dep` VALUES ('S005', '1006');
INSERT INTO `staff_dep` VALUES ('S006', '1005');
INSERT INTO `staff_dep` VALUES ('S007', '1001');
INSERT INTO `staff_dep` VALUES ('S008', '1005');
INSERT INTO `staff_dep` VALUES ('S009', '1005');
INSERT INTO `staff_dep` VALUES ('S010', '1006');
INSERT INTO `staff_dep` VALUES ('S011', '1003');
INSERT INTO `staff_dep` VALUES ('S012', '1002');
INSERT INTO `staff_dep` VALUES ('S013', '1004');
INSERT INTO `staff_dep` VALUES ('S014', '1002');
INSERT INTO `staff_dep` VALUES ('S015', '1006');
INSERT INTO `staff_dep` VALUES ('S016', '1003');
INSERT INTO `staff_dep` VALUES ('S017', '1001');
INSERT INTO `staff_dep` VALUES ('S018', '1005');
INSERT INTO `staff_dep` VALUES ('S019', '1003');
INSERT INTO `staff_dep` VALUES ('S020', '1002');
INSERT INTO `staff_dep` VALUES ('S021', '1001');
INSERT INTO `staff_dep` VALUES ('S022', '1004');
INSERT INTO `staff_dep` VALUES ('S023', '1004');
INSERT INTO `staff_dep` VALUES ('S024', '1002');
INSERT INTO `staff_dep` VALUES ('S025', '1001');
INSERT INTO `staff_dep` VALUES ('S026', '1004');
PHP Code นะครับ
Code (PHP)
<?php
require_once("conn.php");
//############## อย่าลืมประกาศตัวแปรที่ใช้เชื่อมต่อของคุณมาเองนะครับในที่นี้ใช้ตัวแปรชื่อว่า $conn ###############
$html=""; // เอาไว้เก็บ html string ที่ต่อๆกันแล้วไป echo ทีเดียว
$html .='<html>';
$html .='<head>';
$html .='<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />';
$html .='<title>Loop to controls</title>';
$html .='</head>';
$html .='<body>';
$html .='<form method="post" action="">';
$html .='<TABLE border="1">';
$html .='<tr>';
$html .='<td align="center"><b>รหัสหน่วยงาน</b></td>';
$html .='<td align="center"><b>ชื่อหน่วยงาน</b></td>';
$html .='<td align="center"><b>พนักงานในหน่วยงาน</b></td>';
$html .='</tr>';
$sql_dep ="SELECT dep_id,dep_name FROM department ORDER BY dep_id;";
$query_dep = mysql_query($sql_dep,$conn) or die(mysql_error());
while ($dep_row = mysql_fetch_array($query_dep)) {
$html .='<tr>';
$html .='<td>'.$dep_row[dep_id].'</td>';
$html .='<td>'.$dep_row[dep_name].'</td>';
$html .='<td width="400px;">';
//############Loop Staff of Department Here###############
$sql_staff=" SELECT staff.staff_id, staff.staff_name ";
$sql_staff.=" FROM staff_dep INNER JOIN staff ON staff.staff_id = staff_dep.staff_id ";
$sql_staff.=" WHERE staff_dep.dep_id='".$dep_row[dep_id]."'; ";
$query_staff = mysql_query($sql_staff,$conn) or die(mysql_error());
while ($staff_row = mysql_fetch_array($query_staff)) {
$html .='<input type="checkbox" id="'.$staff_row[staff_id].'" value="'.$staff_row[staff_id].'">'.$staff_row[staff_name];
}
//############End Loop Staff of Department Here###########
$html .='</td>';
$html .='</tr>';
}
$html .='</TABLE>';
$html .='</form>';
$html .='</body>';
$html .='</html>';
echo $html; //response html stream
?>
|
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 :
2014-09-26 16:03:45 |
By :
โปรแกรมมั่ว |
|
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="" |
|
ลูปซ้อนลูปไปเลยครับ ไม่ยุ่งยาก แค่ 2 ลูปได้ผลลัพท์
ภาพโฟลล์ชาร์จในเวอร์ชั่นแบบกันเอง data:image/s3,"s3://crabby-images/b73e6/b73e66267ffc0f0687b74c890b15376caab35fc8" alt="" data:image/s3,"s3://crabby-images/b73e6/b73e66267ffc0f0687b74c890b15376caab35fc8" alt=""
data:image/s3,"s3://crabby-images/e0788/e0788c0bf684f15d45640db2efe1506d3860f657" alt="8778 8778"
|
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 :
2014-09-26 16:46:52 |
By :
meannerss |
|
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="" |
|
mysql นะ
Code (SQL)
select dep,group_concat(concat('<input type="checkbox" name="',emp_id,'" >',emp_name)) as checkbox from employee group by dep
Code (PHP)
while($rs = $db.......){
echo $rs['dep'].$rs['checkbox']
}
ms
ใช้
for xml path ลองหาดูครับ
|
ประวัติการแก้ไข 2014-09-26 17:10:23 2014-09-26 17:12:14
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 :
2014-09-26 17:05:27 |
By :
gaowteen |
|
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="" |
|
ได้เเล้วครับ ขอบคุณทุก Comment..data:image/s3,"s3://crabby-images/5f168/5f168d65d220b10a38d406b2f613837da60a55a6" 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 :
2014-09-27 09:08:00 |
By :
junior_dev |
|
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 00
|