|
|
|
ทำระบบสุ่มวันทำงานกะเช้า กับ กะบ่าย โดนแบ่งจำนวนวันเท่าๆกัน จะสุ่มอย่างไรดีค่ะ |
|
|
|
|
|
|
|
ทำระบบสุ่มวันทำงานกะเช้า กับ กะบ่าย
จะทำการสุ่มยังไงหรอค่ะ
H คือ กะเช้า
A คือ กะบ่าย
F คือ วันหยุด จะถูกระบุไว้แล้ว
database ถูกออกแบบเป็นแบบนี้ค่ะ (มีเดิอน, ปี, วัน1 -วันที่ 31)
จะทำการสุ่มยังไงหรอค่ะ โดยต้องแบ่งกะเช้า กับ กะบ่ายเท่ากัน คือ
มี 31 วัน หักวันหยุดไป 7 วัน เหลือวันทำงาน 24 แบ่งเป็นกะเช้า 12 กะบ่าย 12
จะกำหนดอย่างไรหรอค่ะ
ขอคำแนะนำด้วยค่ะ
table ค่ะ
Code (SQL)
--
-- Table structure for table `tb_schedule`
--
CREATE TABLE `tb_schedule` (
`sche_id` int(11) NOT NULL,
`sche_month` int(11) NOT NULL,
`sche_year` int(11) NOT NULL,
`day_1` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_2` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_3` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_4` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_5` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_6` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_7` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_8` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_9` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_10` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_11` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_12` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_13` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_14` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_15` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_16` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_17` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_18` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_19` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_20` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_21` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_22` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_23` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_24` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_25` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_26` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_27` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_28` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_29` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_30` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`day_31` varchar(1) COLLATE utf8_unicode_ci NOT NULL,
`num_off` int(11) NOT NULL,
`num_sunday` int(11) NOT NULL,
`id_call` int(11) NOT NULL,
`cre_dat` datetime NOT NULL,
`upd_dat` datetime NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
--
-- Dumping data for table `tb_schedule`
--
INSERT INTO `tb_schedule` (`sche_id`, `sche_month`, `sche_year`, `day_1`, `day_2`, `day_3`, `day_4`, `day_5`, `day_6`, `day_7`, `day_8`, `day_9`, `day_10`, `day_11`, `day_12`, `day_13`, `day_14`, `day_15`, `day_16`, `day_17`, `day_18`, `day_19`, `day_20`, `day_21`, `day_22`, `day_23`, `day_24`, `day_25`, `day_26`, `day_27`, `day_28`, `day_29`, `day_30`, `day_31`, `num_off`, `num_sunday`, `id_call`, `cre_dat`, `upd_dat`) VALUES
(8, 12, 2016, '', '', '', 'F', '', '', '', '', 'F', 'F', 'F', '', '', '', '', '', '', '', 'F', 'F', 'F', '', '', '', '', '', '', '', '', '', '', 0, 2, 1, '2016-12-21 12:12:10', '0000-00-00 00:00:00');
Tag : PHP, MySQL
|
|
|
|
|
|
Date :
2016-12-22 09:30:00 |
By :
Baitong_ch |
View :
978 |
Reply :
4 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Code (PHP)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>สุ่มกะเช้าบ่าย</title>
</head>
<body>
<div id="result"></div>
<script>
//วันหยุด
var holiday = [4,9,10,11,19,20,21];
//จำนวนวันในหนึ่งเดือน
var month = 31;
//counter array
var c = 0;
//จำนวนวันเช้าบ่าย
var day = night = 0;
//จำนวนวันทำงาน
var workDay = month - holiday.length;
//จำนวนกะบ่ายสูงสุด
var maxNight = Math.floor(workDay/2);
//จำนวนกะเช้าสูงสุด
var maxDay = workDay - maxNight;
// html code
var html = '';
for(i=1;i<=month;i++){
html += "วันที่ " + i + " : ";
//ถ้าเป็นวันหยุด
if(i == holiday[c]){
html += "หยุด<br/>";
c++;
}else{
//ถ้าไม่ใช่วันหยุด
//สุ่มเช้า-บ่าย
var time = Math.floor(Math.random() * 2);
switch(time){
//ถ้าเป็นกะเช้าและวันยังไม่ครบ
case 0:
if(day < maxDay){
html += "เช้า<br/>";
day++;
}else{
html += "บ่าย<br/>";
night++;
}
break;
case 1:
//ถ้าเป็นกะบ่ายและวันยังไม่ครบ
if(night < maxNight){
html += "บ่าย<br/>";
night++;
}else{
html += "เช้า<br/>";
day++;
}
break;
}
}
}
document.getElementById('result').innerHTML = html;
</script>
</body>
</html>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
สอบถามต่ออีกหน่อยค่ะ
ถ้ามีพนักงานทั้งหมด 7 คน
ตอน random A กับ H นั้น อยากให้แต่ละวัน มีจำนวนคนทำงานเท่าๆกันด้วยค่ะ จะต้องทำอย่างไรค่ะ
ขอคำแนะนำด้วยค่ะ
|
|
|
|
|
Date :
2016-12-28 14:45:50 |
By :
Baitong_ch |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ขอคำแนะนำด้วยค่ะ
อยากให้แต่ละวันมีคนทำงานเท่าๆกัน จะrandom ยังไง
|
|
|
|
|
Date :
2017-01-20 14:18:31 |
By :
me |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
เอาโค้ดมาวาง แล้วจะได้ช่วยกันแก้ครับ
|
|
|
|
|
Date :
2017-01-20 17:35:32 |
By :
deawx |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 04
|