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 > รบกวนสอบถามค้นหาตามช่วงเวลา ที format เป็น Datetime ครับ



 

รบกวนสอบถามค้นหาตามช่วงเวลา ที format เป็น Datetime ครับ

 



Topic : 118303



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



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




รบกวนสอบถามค้นหาตามช่วงเวลา ที format เป็น Datetime ครับ ถ้าในตารางมีวันที่จอง 3 - 10 เวลสา 12.00น.

Code
SELECT * FROM `tb_time` WHERE (start BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00') OR (end BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00')


จะคิวรี่ไม่พบแต่ถ้าวันที่ตรงกัน 3 - 10 หาพบครับ แต่ถ้าไม่ใส่เวลาคิวรี่พบครับ เราต้องแปลงวัันเวลาก็หรือไม่ครับผม



Tag : PHP, MySQL







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-08-09 18:34:54 By : gigiyo View : 1260 Reply : 14
 

 

No. 1



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

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

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

เก็บ Data Type เป็นอะไรครับ Date/Time หรือเปล่า






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-09 20:46:43 By : mr.win
 


 

No. 2



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



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


ตอบความคิดเห็นที่ : 1 เขียนโดย : mr.win เมื่อวันที่ 2015-08-09 20:46:43
รายละเอียดของการตอบ ::
datetime ครับผม แก้ไขครับ ได้แต่ยังคิวรี่มาไม่ครบครับ



ประวัติการแก้ไข
2015-08-09 22:13:51
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-09 21:43:59 By : gigiyo
 

 

No. 3



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



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


Code
WHERE (car_r_start_date BETWEEN CAST('$d_start' AS DATETIME) AND CAST('$d_end' AS DATETIME)) OR (car_r_end_date BETWEEN CAST('$d_start' AS DATETIME) AND CAST('$d_end' AS DATETIME))

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-09 22:14:50 By : gigiyo
 


 

No. 4



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



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

Code (SQL)
SELECT * FROM `tb_time` 
WHERE ( start  BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00') 
OR ( end BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00')


ลองเพิ่ม backquote ครอบฟีลด์เข้าไปด้วยครับ
Code (SQL)
SELECT * FROM `tb_time` 
WHERE ( `start` BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00') 
OR ( `end` BETWEEN '2015-08-05 12:00' and '2015-08-08 12:00')

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 00:07:39 By : NewbiePHP
 


 

No. 5



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



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


ตอนนี้คิวรี่ได้เฉพาะ ที่ระบุวันที่ตรงกับวันเริ่มหรือวันคืนครับระหว่าง วันเริ่มและคืน ค้าหาไม่พบครับ

โดยใช้แบบนี้ครับ
$d_start =2015-08-01 12:00:00
'$d_end =2015-08-05 12:00:00

ตารางข้อมูลตามนี้ครับ



ผมได้ลอง 3 แบบค้นหาได้เฉพาะวันที่ตรงกันเท่านั้นครับผมอยากให้ระหว่างวันที่ด้วยครับ ไม่รู้ผมต้อง where แบบไหนถึงครบคุมครับปม
แบบที่1
Code (PHP)
WHERE ((car_r_start_date BETWEEN '$d_start' and '$d_end') OR (car_r_end_date BETWEEN '$d_start' and '$d_end')


แบบที่2
Code (PHP)
WHERE (car_r_start_date BETWEEN CAST('$d_start' AS DATETIME) AND CAST('$d_end' AS DATETIME)) OR (car_r_end_date BETWEEN CAST('$d_start' AS DATETIME) AND CAST('$d_end' AS DATETIME))


แบบที่3
Code (PHP)
$query_Re_car_r .= "WHERE (car_r_start_date <= CAST($d_start AS DATETIME)) AND car_r_end_date >= CAST($d_start AS DATETIME)) OR (car_r_end_date >= CAST($d_end AS DATETIME)) AND car_r_start_date <= CAST($d_end AS DATETIME))

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 09:19:32 By : gigiyo
 


 

No. 6



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



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


ลอง Convert รูปแบบ DateTime ดูครับ
// อันนี้ของ SQL Server
// http://www.w3schools.com/sql/func_convert.asp
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 09:50:06 By : CasanovaKung
 


 

No. 7



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



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


จากข้อมูลในตารางออกมาตามรูปแบบนี้ครับ




ผมใช้ where แบบนี่
Code (PHP)
WHERE ((car_r_start_date BETWEEN '$d_start' and '$d_end') OR (car_r_end_date BETWEEN '$d_start' and '$d_end')


1.ถ้าเลือก d_start = วันที่ 2 เวลา 12.00 และ d_end = วันที่ 4 เวลา 16.00
ผลที่ได้คือพบว่ามีจองช่วงเวลานี้ แค่ 2 รายการ
4. / กค-1234 2015-09-01 12:00:00 - 2015-09-04 12:00:00
5. / กค-1234 2015-09-04 15:00:00 - 2015-09-08 12:00:00
ที่ถูกต้องน่าจะเป็นแบบนี้
1. / กข-1001 2015-09-01 12:00:00 - 2015-09-05 12:00:00
4. / กค-1234 2015-09-01 12:00:00 - 2015-09-04 12:00:00
5. / กค-1234 2015-09-04 15:00:00 - 2015-09-08 12:00:00

2.ผมเลือก d_start = วันที่ 2 เวลา 12.00 และ d_end = วันที่ 9 เวลา 16.00
ผลออกมาถูกต้องเลยงง ทำไม เรคคอร์ดที่ 1 ถึงไม่พบตามข้อ 1.
1. / กข-1001 2015-09-01 12:00:00 - 2015-09-05 12:00:00
4. / กค-1234 2015-09-01 12:00:00 - 2015-09-04 12:00:00
5. / กค-1234 2015-09-04 15:00:00 - 2015-09-08 12:00:00


ประวัติการแก้ไข
2015-08-10 10:46:40
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 10:43:10 By : gigiyo
 


 

No. 8



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



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


result ที่ได้มันก็ถูกแล้วหนิครับ
แต่สิ่งที่ต้องการ กับ คำสั่ง SQL มันไม่เหมือนกัน

ที่ต้องการ
น่าจะเป็นแบบนี้นะ

Code (SQL)
SELECT * FROM `118303` WHERE UNIX_TIMESTAMP('2015-09-02 12:00:00') BETWEEN UNIX_TIMESTAMP(sd) AND UNIX_TIMESTAMP(ed)
OR UNIX_TIMESTAMP('2015-09-04 16:00:00') BETWEEN UNIX_TIMESTAMP(sd) AND UNIX_TIMESTAMP(ed)


Data ==>
Code (SQL)
CREATE TABLE IF NOT EXISTS `118303` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `data` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  `sd` datetime DEFAULT NULL,
  `ed` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

DELETE FROM `118303`;
/*!40000 ALTER TABLE `118303` DISABLE KEYS */;
INSERT INTO `118303` (`id`, `data`, `sd`, `ed`) VALUES
	(1, 'กข-1001', '2015-09-01 12:00:00', '2015-09-05 12:00:00'),
	(2, 'กข-1001', '2015-09-10 12:00:00', '2015-09-15 12:00:00'),
	(3, 'กข-1234', '2015-09-01 12:00:00', '2015-09-04 12:00:00'),
	(4, 'กข-1234', '2015-09-04 15:00:00', '2015-09-08 12:00:00');

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 11:22:52 By : CasanovaKung
 


 

No. 9



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



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


ตอบความคิดเห็นที่ : 8 เขียนโดย : CasanovaKung เมื่อวันที่ 2015-08-10 11:22:52
รายละเอียดของการตอบ ::
ขอบคุณครับ ทดลองแล้วครับปัญหาตามข้อ 1. หายไปครับ แต่ถ้าข้อมูลวันที่อยู่ในช่วง ระหว่างวันที่ค้นหาจะหาไม่พบครับผม
เช่น ค้นหา 3 - 10 ในฐานข้อมูลมีข้อมูล 4 - 8 มันหาไม่พบครับ
คือผมต้องการค้นหาว่าช่วงเวลาที่ค้นหา มีใครใช้อยู่บ้างครับ



ประวัติการแก้ไข
2015-08-10 11:51:28
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 11:51:03 By : gigiyo
 


 

No. 10



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



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


ก็ใส่เงื่อนไขเพิ่มให้มันครบ สิครับ

Code (SQL)
SET @SD = '2015-09-03 12:00:00';
SET @ED = '2015-09-10 16:00:00';
SELECT * FROM `118303` WHERE UNIX_TIMESTAMP(@SD) BETWEEN UNIX_TIMESTAMP(sd) AND UNIX_TIMESTAMP(ed)
OR UNIX_TIMESTAMP(@ED) BETWEEN UNIX_TIMESTAMP(sd) AND UNIX_TIMESTAMP(ed)
OR UNIX_TIMESTAMP(sd) BETWEEN UNIX_TIMESTAMP(@SD) AND UNIX_TIMESTAMP(@ED) 
OR UNIX_TIMESTAMP(ed) BETWEEN UNIX_TIMESTAMP(@SD) AND UNIX_TIMESTAMP(@ED) 

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 12:05:40 By : CasanovaKung
 


 

No. 11



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



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


// แบบหาวันที่ค่อม วันเริ่ม และ สิ้นสุด แบบนี้ได้มันน่าจะได้แต่ผมลองแล้วไม่ได้อีก
(
UNIX_TIMESTAMP('$d_start') <= UNIX_TIMESTAMP(car_r_start_date)
AND
UNIX_TIMESTAMP('$d_end') => UNIX_TIMESTAMP(car_r_end_date)
)
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 12:17:30 By : gigiyo
 


 

No. 12



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



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


Code (SQL)
WHERE 
 (
 UNIX_TIMESTAMP('$d_start') >= UNIX_TIMESTAMP(car_r_start_date)
 AND 
 UNIX_TIMESTAMP('$d_start') <= UNIX_TIMESTAMP(car_r_end_date)
 ) 
 
 OR 
 
 (
 UNIX_TIMESTAMP('$d_end') >= UNIX_TIMESTAMP(car_r_start_date) 
 AND 
 UNIX_TIMESTAMP('$d_end') <= UNIX_TIMESTAMP(car_r_end_date)
 ) 
 
 OR
 
 (
 UNIX_TIMESTAMP('$d_start') <= UNIX_TIMESTAMP(car_r_start_date) 
 AND 
 UNIX_TIMESTAMP('$d_end') => UNIX_TIMESTAMP(car_r_end_date)
 )


แบบนี้ ออกมาืุกเรทคอร์ดเลย


ประวัติการแก้ไข
2015-08-10 12:31:46
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 12:18:44 By : gigiyo
 


 

No. 13



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



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


ตอบความคิดเห็นที่ : 10 เขียนโดย : CasanovaKung เมื่อวันที่ 2015-08-10 12:05:40
รายละเอียดของการตอบ ::
อันนี้ ลองแล้ว ใช่มั้ย??

ลองหาเคส ที่ต้องการผลลัพธ์ มาสัก 5-6 เคสดู


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 12:43:38 By : CasanovaKung
 


 

No. 14



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



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


ตอบความคิดเห็นที่ : 13 เขียนโดย : CasanovaKung เมื่อวันที่ 2015-08-10 12:43:38
รายละเอียดของการตอบ ::
ขอบคุณครับได้เรียบร้อยครับ ขอบคุณสำหรับคำแนะนำใช้ UNIX_TIMESTAMP ครับ ผมเปลี่ยนแปลงตามความต้องการอีกนิดใช้ได้ครับครับ


Code (SQL)
 WHERE(((UNIX_TIMESTAMP('2015-09-09 12:00') >= UNIX_TIMESTAMP(car_r_start_date)) AND (UNIX_TIMESTAMP('2015-09-09 12:00') <= UNIX_TIMESTAMP(car_r_end_date))) OR ((UNIX_TIMESTAMP('2015-09-16 13:00') >= UNIX_TIMESTAMP(car_r_start_date)) AND (UNIX_TIMESTAMP('2015-09-16 13:00') <= UNIX_TIMESTAMP(car_r_end_date))) OR ((UNIX_TIMESTAMP('2015-09-09 12:00') <= UNIX_TIMESTAMP(car_r_start_date)) AND (UNIX_TIMESTAMP('2015-09-09 12:00') <= UNIX_TIMESTAMP(car_r_end_date)) AND (UNIX_TIMESTAMP('2015-09-16 13:00') >= UNIX_TIMESTAMP(car_r_start_date)) AND (UNIX_TIMESTAMP('2015-09-16 13:00') >= UNIX_TIMESTAMP(car_r_end_date))))

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-08-10 13:27:25 By : gigiyo
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : รบกวนสอบถามค้นหาตามช่วงเวลา ที format เป็น Datetime ครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 00
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 อัตราราคา คลิกที่นี่