ข้ามไปที่เนื้อหาหลัก

SQL สำหรับตรวจสอบช่วงเวลาที่ว่าง สำหรับระบบจองห้อง ต่างๆ


นอกจากระบบจองห้องประชุมแล้ว น่าจะรวมถึงระบบจอง อื่นๆ ที่มีเรื่องวันที่ และเวลาเข้ามาเกี่ยวข้องด้วย ในรูปจะเป็นการค้นหาช่วงเวลาที่ทับซ้อนกัน


สำหรับคำสั่งที่ใช้ตรวจสอบเวลาที่จองห้อง จะเป็นดังนี้



<?php

$id = $_POST['room_id'];
$bkDate = $_POST['booking_date'];
$startTime = $_POST['start_time'];
$endTime = $_POST['end_time'];

//ค้นหาว่ามีการจอง หรือยัง
$sql = "SELECT * FROM tb_booking WHERE bk_room_id = '".$id."' 
AND bk_date = '".$bkDate."' 
AND (
   (bk_start_time BETWEEN '".$startTime."' AND '".$endTime."') 
   OR (bk_end_time BETWEEN '".$startTime."' AND '".$endTime."')
)";
$qry = mysql_query($sql) or die(mysql_error());
if($row = mysql_fetch_array($qry))
{
echo "ห้องนี้มีผู้ใช้งาน ช่วงเวลา ". $row['bk_start_time'] ." - ". $row['bk_end_time'] ." กรุณาตรวจสอบอีกครั้ง!";
}
?>



คำสั่งด้านบนนี้ จะครบคลุมแค่การเลือกช่วงเวลาคร่อม เวลาเริ่ม หรือ คร่อมเวลา สิ้นสุด การใช้ห้องเท่านั้น

หากมีการเลือกช่วงเวลาที่อยู่ ระหว่าง เวลาจอง เริ่มต้น ถึงเวลาจองสิ้นสุด จะทำให้ไม่เข้าเงื่อนไขว่ามีคนจอง เช่นเลือกช่วง 12:50 - 14.30 ทั้งที่ช่วงเวลา 18:15 - 16:15 มีคนใช้ห้องอยู่
ดังนั้นเราจะต้องเพิ่มเงื่อนไขเข้าไปด้วยว่า เลือกช่วงเวลาระหว่างใช้ห้องไม่ได้

<?php
$sql = "SELECT * FROM tb_booking WHERE bk_room_id = '".$id."'
AND bk_date = '".$bkDate."'
AND (

   (bk_start_time BETWEEN '".$startTime."' AND '".$endTime."')
   OR 
   (bk_end_time BETWEEN '".$startTime."' AND '".$endTime."')
   OR 
    ('".$startTime."' BETWEEN bk_start_time  AND bk_end_time)
   OR 
    ('".$endTime."' BETWEEN  bk_start_time  AND bk_end_time )
)";
?>
?>



แต่เมื่อพิจารณาคำสั่ง SQL ดูแล้วพบว่า อีกสองเงื่อนไขที่เพิ่มมาใหม่นั้นครบคลุม ทั้ง 3 กรณีแล้ว สามารถตัดเงื่อนไขบางเงื่อนไขออกไปได้ จะได้เป็น

<?php
$sql = "SELECT * FROM tb_booking WHERE bk_room_id = '".$id."'
AND bk_date = '".$bkDate."'
AND (

   ('".$startTime."' BETWEEN bk_start_time  AND bk_end_time)
   OR 
   ('".$endTime."' BETWEEN  bk_start_time  AND bk_end_time )
)";
?>

@2013-08-09 แก้ไขโค๊ดที่ถูกตัดทอนในตอนท้าย นำไปใช้จริงแล้วจะมีหลุดกรณีเลือกช่วงเวลาคร่อมกับช่วงเวลาที่จองไปแล้ว ให้ใช้โค๊ดส่วนที่ยังไม่ได้ตัดทอนแทนนะครับ




ลองนำไปปรับใช้กันดูนะครับ


บทความแนะนำ
ส่วนแสดงผล แบบระบายสีตามช่วงเวลา

อ่านบทความเกี่ยวกับ SQL สำหรับระบบจองห้องพักได้ที่
ตัวอย่าง SQL สำหรับเช็คห้องว่าง สำหรับระบบจองห้องพัก 
http://phpcodemania.blogspot.com/2018/07/php-sql-room-booking-available.html


 
ปล. จากคอมเมนต์ของคุณ @Komkit ทดสอบแล้วทำงานได้เช่นกันครับ เพียงแค่เปลี่ยนจาก OR เป็น AND
select * From ReserveRoomWhere (RoomID =@RoomID)and (BeginDate <=@EndDate)and (EndDate >=@BeginDate)
 
 


"PHP ไม่ได้สร้างสุดยอดโปรแกรม
แต่ PHP ช่วยให้งานคุณง่ายขึ้นต่างหาก"

PHP CI MANIA PHP Code Generator 
โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม

สนใจสั่งซื้อเพียง 3,990 บาท



PHP CI MANIA PHP Code Generator 

โปรแกรมช่วยสร้างโค้ด "ลดเวลาการเขียนโปรแกรม"
ราคาสุดคุ้มเพียง 3,990 บาท 
http://www.phpcodemania.com

ความคิดเห็น

โพสต์ยอดนิยมจากบล็อกนี้

แจกฟรี!! ระบบต่างๆที่พัฒนาด้วย PHP สำหรับนำไปใช้ในงานต่างๆ

       สำหรับหลายท่านที่ขอโค้ดเข้ามาทาง Inbox ของเฟซบุ๊กแฟนเพจ หรือถามถึงระบบต่างๆหลังไมค์มานั้น ส่วนใหญ่ก็มีแจกอยู่แล้วในเว็บบอร์ด ThaiCreate.Com นะครับ และด้านล่างนี้ก็เป็นระบบต่างๆที่แจกให้นำไปลองใช้ลองศึกษากันครับ

สอนเขียน PHP แสดงการจองห้องประชุมแบบไฮไลท์ตามช่วงเวลา (แบบเชื่อมต่อฐานข้อมูล MySQL)

ตัวอย่าง ผลลัพธ์ที่ได้จากการจองในฐานข้อมูล ตาราง tb_room สร้างตารางรายชื่อห้องประชุม สำหรับ id นั้นเป็น Primarykey จะกำหนดให้สร้างอัตโนมัติ ทุกครั้งที่เราเพิ่มชื่อห้องประชุมใหม่ -- -- Database: `tobedev_example` -- -- -------------------------------------------------------- -- -- Table structure for table `tb_room` -- CREATE TABLE IF NOT EXISTS `tb_room` (   `id` int(11) NOT NULL,   `name` varchar(30) NOT NULL ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8; -- -- Dumping data for table `tb_room` -- INSERT INTO `tb_room` (`id`, `name`) VALUES (1, 'ห้องประชุม 1'), (2, 'ห้องประชุม 2'), (3, 'ห้องประชุม 3'), (4, 'ห้องประชุม 4'), (5, 'ห้องประชุม 5'); -- -- Indexes for dumped tables -- -- -- Indexes for table `tb_room` -- ALTER TABLE `tb_room`   ADD PRIMARY KEY (`id`); -- -- AUTO_INCREMENT for dumped tables -- -- -- AUTO_INCREMENT for table `tb_room` -- ALTER TABLE `tb_room`   MODIFY `i...

การนำไอคอน มาแสดงบน Fullcalendar

เนื่องจากมีน้องคนหนึ่งให้ช่วยดูโค้ดเกี่ยวกับ Fullcalendar ให้หน่อย แล้วพอดีช่วงนี้ผมก็กำลังสนใจปฏิทิน Fullcalendar อยู่พอดี จึงลองหาสาเหตุที่ไม่สามารถแสดงข้อมูลจาก MySQL และไม่สามารถแทรก icon เข้าไปใน Fullcalendar ได้ จากที่สังเกตุได้ครั้งแรกคือ Error ที่ Console ของ Firefox เกี่ยวกับฟังก์ชั่นที่เขียนผิด และก็มีการ echo ค้างไว้ในส่วนของไฟล์ getCalendar.php ก็เลยจัดการทดสอบแล้วลบ echo ออกให้เหลือแค่ echo json_encode($event_array); ที่ได้ใช้งานจริงเท่านั้น ขั้นตอนการตรวจสอบความถูกต้องของโค้ด PHP 1) ต้องแน่ใจว่าคำสั่งที่เขียนไว้ สามารถดึงข้อมูลมาแสดงผลได้ด้วยการ echo $sql; 2) นำคำสั่งที่ได้ไปรันในโปรแกรมจัดการฐานข้อมูล ในที่นี้คือ phpMyAdmin 3) เมื่อตรวจสอบดูผลลัพธ์ที่ได้ หากถูกต้องมีข้อมูลก็แสดงว่าการ Query ทำงานได้ 4) มาดูการทำงานของ JavaScript ในส่วนของ jQuery มีการแจ้งเตือนที่ฟังก์ชั่น .on() ซึ่งจะใช้กับ jQuery เวอร์ชั่นใหม่เท่านั้น นั่นหมายถึงเวอร์ชั่น jQuery ที่มากับ Fullcalendar เป็นเวอร์ชั่นเก่า ก็ให้เปลี่ยนไปใช้ .live() แทน ก็จะทำงานได้ปกติ 5) ม...