SQL計(jì)算timestamp的差值的方法
概述
有時(shí)候我們需要按照時(shí)間找出某些記錄,比如說(shuō):算出離銷售時(shí)間前1個(gè)小時(shí)的記錄。
通常我們可以使用MYSQL的timestampdiff函數(shù)來(lái)做,但是這樣沒法使用到索引,如果數(shù)據(jù)量大的話,會(huì)造成慢查詢。
用代碼計(jì)算出時(shí)間后再傳給SQL
我們可以利用JAVA代碼,先把時(shí)間計(jì)算好,然后傳給SQL語(yǔ)句,避免使用MYSQL的函數(shù)。
public long xxxx(long sellTimeFrom){
Calendar calendar = Calendar.getInstance();
calendar.setTime(new Date(sellTimeFrom));
calendar.set(Calendar.HOUR_OF_DAY,calendar.get(Calendar.HOUR_OF_DAY) - 1);
return calendar.getTime().getTime();
}
這樣就可以算出銷售時(shí)間前一個(gè)小時(shí)的時(shí)間。然后傳入SQL這里寫代碼片`語(yǔ)句中,這樣如果銷售時(shí)間字段有建立索引,是可以用上索引的。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
您可能感興趣的文章:- MySQL timestamp的類型與時(shí)區(qū)實(shí)例詳解
- mysql之TIMESTAMP(時(shí)間戳)用法詳解
- MySQL錯(cuò)誤TIMESTAMP column with CURRENT_TIMESTAMP的解決方法
- MySQL timestamp自動(dòng)更新時(shí)間分享
- Sqlserver timestamp數(shù)據(jù)類使用介紹
- mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函數(shù)