2017-01-09 62 views
0

可能有很多次被問到,但我有一張有一些記錄的表。一些與明天的日期和一些明天的一些。我嘗試以下方法從今天到明天都不能得到正確的mySQL記錄

SELECT * FROM Games where GAMEID='".$id."' AND GAMEDATE >=CURDATE() + INTERVAL 1 DAY 

而且我獲得了日期爲10/1/2017和2017/1/1的記錄。不應該INTERVAL 1天只得到2017年10月1日的日期?

如果我使用

GAMEDATE >= DATE_SUB(CURDATE(), INTERVAL 1 DAY) AND GAMEDATE <= CURDATE() 

我得到空查詢

回答

1

,如果你想只從明天

記錄嘗試此查詢

select * from Games where GAMEDATE between curdate() + interval 1 day 
and 
curdate() + interval 2 day and GAMEID='".$id."'; 

檢查演示表

sqlfiddle

0

嘗試DATE_ADD(CURDATE(), INTERVAL 1 DAY)代替

0

你不能只是用另外這樣。您需要使用DATE_ADD()

GAMEDATE >= DATE_ADD(CURDATE(), INTERVAL 1 DAY); 

如果你想往回走,你會用DATE_SUB

+0

我再次得到記錄與2017年11月1日,而不是一起只2017/10/01 – Evridiki

+0

當你說「10/01/2017」你是指2017年10月1日或2017年一月十日? –

+0

2017年1月10日 – Evridiki