mybatis查詢時間段sql語句和DATE_FORMAT【轉】


1、mysql 格式化日期 DATE_FORMAT,FROM_UNIXTIME,UNIX_TIME等

 

 DATE_FORMAT() 函數用於以不同的格式顯示日期/時間數據。
Sql代碼   收藏代碼
  1. DATE_FORMAT(date,format)     重點
 

可以使用的格式有:

格式 描述
%a 縮寫星期名
%b 縮寫月名
%c 月,數值
%D 帶有英文前綴的月中的天
%d 月的天,數值(00-31)
%e 月的天,數值(0-31)
%f 微秒
%H 小時 (00-23)
%h 小時 (01-12)
%I 小時 (01-12)
%i 分鍾,數值(00-59)
%j 年的天 (001-366)
%k 小時 (0-23)
%l 小時 (1-12)
%M 月名
%m 月,數值(00-12)
%p AM 或 PM
%r 時間,12-小時(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 時間, 24-小時 (hh:mm:ss)
%U 周 (00-53) 星期日是一周的第一天
%u 周 (00-53) 星期一是一周的第一天
%V 周 (01-53) 星期日是一周的第一天,與 %X 使用
%v 周 (01-53) 星期一是一周的第一天,與 %x 使用
%W 星期名
%w 周的天 (0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,與 %V 使用
%x 年,其中的星期一是周的第一天,4 位,與 %v 使用
%Y 年,4 位
%y 年,2 位

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

實例

下面的腳本使用 DATE_FORMAT() 函數來顯示不同的格式。我們使用 NOW() 來獲得當前的日期/時間:

Sql代碼   收藏代碼
  1. DATE_FORMAT(NOW(),'%b %d %Y %h:%i %p')  
  2. DATE_FORMAT(NOW(),'%m-%d-%Y')  
  3. DATE_FORMAT(NOW(),'%d %b %y')  
  4. DATE_FORMAT(NOW(),'%d %b %Y %T:%f')  
 

結果類似:

Sql代碼   收藏代碼
  1. Dec 29 2008 11:45 PM  
  2. 12-29-2008  
  3. 29 Dec 08  
  4. 29 Dec 2008 16:25:46  
 

如果要格式表中的數據,可以用:

 

 MySQL 數據庫中日期與時間函數 FROM_UNIXTIME(), UNIX_TIME() ...

 

實例: date => int(11)

Sql代碼   收藏代碼
  1. SELECT FROM_UNIXTIME(date, '%Y-%c-%d %h:%i:%s' ) as post_date ,   
  2. date_format(NOW(), '%Y-%c-%d %h:%i:%s' ) as post_date_gmt   
  3. FROM `article`  where outkey = 'Y'  

 

FROM_UNIXTIME( unix_timestamp ) 
參數:通常是壹個十位的數字,如:1344887103 
返回值:有兩種,可能是類似 'YYYY-MM-DD HH:MM:SS' 這樣的字符串,也有可能是類似於 YYYYMMDDHHMMSS.uuuuuu 這樣的數字,具體返回什么取決於該函數被調用的形式。

Sql代碼   收藏代碼
  1. mysql> select FROM_UNIXTIME(1344887103);  
  2. +---------------------------+  
  3. | FROM_UNIXTIME(1344887103) |  
  4. +---------------------------+  
  5. | 2012-08-14 03:45:03       |  
  6. +---------------------------+  
  7. 1 row in set (0.00 sec)  
 

FROM_UNIXTIME( unix_timestamp ,format ) 
參數 unix_timestamp :與方法 FROM_UNIXTIME( unix_timestamp ) 中的參數含義一樣; 
參數 format : 轉換之后的時間字符串顯示的格式; 
返回值:按照指定的時間格式顯示的字符串;

Sql代碼   收藏代碼
  1. mysql> select FROM_UNIXTIME(1344887103,'%Y-%M-%D %h:%i:%s');  
  2. +-----------------------------------------------+  
  3. | FROM_UNIXTIME(1344887103,'%Y-%M-%D %h:%i:%s') |  
  4. +-----------------------------------------------+  
  5. | 2012-August-14th 03:45:03                     |  
  6. +-----------------------------------------------+  
  7. 1 row in set (0.00 sec)  
  8. mysql> select FROM_UNIXTIME(1344887103,'%Y-%m-%D %h:%i:%s');  
  9. +-----------------------------------------------+  
  10. | FROM_UNIXTIME(1344887103,'%Y-%m-%D %h:%i:%s') |  
  11. +-----------------------------------------------+  
  12. | 2012-08-14th 03:45:03                         |  
  13. +-----------------------------------------------+  
  14.   
  15. 1 row in set (0.00 sec)  
 

 

 

UNIX_TIMESTAMP()

返回值:當前時間的UNIX格式數字串,或者說是 UNIX 時間戳(從 UTC 時間'1970-01-01 00:00:00'開始的秒數),通常為十位,如 1344887103。

Sql代碼   收藏代碼
  1. mysql> select unix_timestamp();  
  2. +------------------+  
  3. | unix_timestamp() |  
  4. +------------------+  
  5. |       1344887103 |  
  6. +------------------+  
  7. 1 row in set (0.00 sec)  
 

UNIX_TIMESTAMP( date ) 
參數:date 可能是個 DATE 字符串,DATETIME 字符串,TIMESTAPE 字符串,或者是一個類似於 YYMMDD 或者 YYYYMMDD 的數字串。 
返回:從 UTC 時間'1970-01-01 00:00:00'開始到該參數之間的秒數。服務器將參數 date 解釋成當前時區的壹個值並且將其轉化成 UTC 格式的內部時間。客戶端則可以自行設置當前時區。當 UNIX_TIMESTAMP() 用於壹個 TIMESTAMP 列時,函數直接返回內部時間戳的值;如果你傳遞壹個超出范圍的時間到 UNIX_TIMESTAMP(),它的返回值是零。

Sql代碼   收藏代碼
  1. mysql> SELECT UNIX_TIMESTAMP();  
  2. +------------------+  
  3. | UNIX_TIMESTAMP() |  
  4. +------------------+  
  5. |       1344888895 |  
  6. +------------------+  
  7. 1 row in set (0.00 sec)  
  8.   
  9. mysql> SELECT UNIX_TIMESTAMP('2012-08-14 16:19:23');  
  10. +---------------------------------------+  
  11. | UNIX_TIMESTAMP('2012-08-14 16:19:23') |  
  12. +---------------------------------------+  
  13. |                            1344932363 |  
  14. +---------------------------------------+  
  15. 1 row in set (0.00 sec)  
 

注意:如果你使用 UNIX_TIMESTAMP() 和 FROM_UNIXTIME() 來轉換 TIMESTAMP 值與 Unix 時間戳的值,精度會丟失,因為這個映射在兩個方向上不是一一對應的。比如說,由於本地時區的更改,有可能兩個 UNIX_TIMESTAMP() 會映射到同壹個 Unix 時間戳的值。 FROM_UNIXTIME() 只會映射到原來的那個時間戳的值上。這里有個例子,在 CET 時區使用 TIMESTAMP:

Sql代碼   收藏代碼
  1. mysql> SELECT UNIX_TIMESTAMP('2005-03-27 03:00:00');  
  2. +---------------------------------------+  
  3. | UNIX_TIMESTAMP('2005-03-27 03:00:00') |  
  4. +---------------------------------------+  
  5. |                            1111885200 |  
  6. +---------------------------------------+  
  7. mysql> SELECT UNIX_TIMESTAMP('2005-03-27 02:00:00');  
  8. +---------------------------------------+  
  9. | UNIX_TIMESTAMP('2005-03-27 02:00:00') |  
  10. +---------------------------------------+  
  11. |                            1111885200 |  
  12. +---------------------------------------+  
  13. mysql> SELECT FROM_UNIXTIME(1111885200);  
  14. +---------------------------+  
  15. | FROM_UNIXTIME(1111885200) |  
  16. +---------------------------+  
  17. | 2005-03-27 03:00:00       |  
  18. +---------------------------+  

2、

需要查詢db2數據庫表某個時間區間,例如查詢user表從2017-01-01到2017-01-31這一個月新增的用戶數據,或者只想傳一個開始日期beginDate(結束日期endDate)作為條件查詢,查詢這個beginDate之后或endDate之前所有的新增用戶數量

  1.  
    < if test='beginDate!=null or endDate!=null '>
  2.  
    and d.LAST_UPT_DATE between #{beginDate,jdbcType=VARCHAR} and #{endDate,jdbcType=VARCHAR}
  3.  
    </ if>
  • 1
  • 2
  • 3

只要任意一個不為空,都可以查出表中beginDate之前或endDate之后或beginDate 和endDate區間的數據。 
db2執行的查詢語句between?and?,“?”處允許有一個值為空。

3、mybatis查詢時間段sql語句

 

轉載自:http://blog.csdn.net/zl544434558/article/details/24428307?utm_source=tuicool&utm_medium=referral

頁面表現形式:

查詢Ro

頁面傳過來的就是字符串

復制代碼
public class QueryRo {

    private String beginTime;

    private String endTime;

    public String getBeginTime() {
        return beginTime;
    }

    public void setBeginTime(String beginTime) {
        this.beginTime = beginTime;
    }

    public String getEndTime() {
        return endTime;
    }

    public void setEndTime(String endTime) {
        this.endTime = endTime;
    }
}
復制代碼

在項目中查詢時間段的sql語句(時間類型為datetime或date)(數據庫中的時間類型):

<if test="beginTime!=null and beginTime!=''">
    <![CDATA[   and DATE_FORMAT(tr.add_time, '%Y-%m-%d')>=  DATE_FORMAT(#{beginTime}, '%Y-%m-%d')   ]]>
</if>
<if test="endTime!=null and endTime!=''">
    <![CDATA[  and DATE_FORMAT(tr.add_time, '%Y-%m-%d') <= DATE_FORMAT(#{endTime}, '%Y-%m-%d')    ]]>
</if>
 
           
 
           
tr.add_time(數據庫中的時間)  
beginTime 和endTime  對比的時間

在項目中查詢時間段的sql語句(時間類型為varchar)(數據庫中的時間類型):

<if test="beginTime!=null and beginTime!=''">
  AND tm.add_time&gt;=#{beginTime} 
</if> <if test="endTime!=null and endTime!=''">   AND tm.add_time &lt;=#{endTime}
</if>

&lt;小於號  <      &gt; 大於號>

附:

MySQL DATE_FORMAT() 函數

定義和用法

DATE_FORMAT() 函數用於以不同的格式顯示日期/時間數據。

語法

DATE_FORMAT(date,format)

date 參數是合法的日期。format 規定日期/時間的輸出格式。

可以使用的格式有:看上邊

實例

下面的腳本使用 DATE_FORMAT() 函數來顯示不同的格式。我們使用 NOW() 來獲得當前的日期/時間:

DATE_FORMAT(NOW(),'%b %d %Y %h:%i %p')
DATE_FORMAT(NOW(),'%m-%d-%Y')
DATE_FORMAT(NOW(),'%d %b %y')
DATE_FORMAT(NOW(),'%d %b %Y %T:%f')

結果類似:

Dec 29 2008 11:45 PM
12-29-2008
29 Dec 08
29 Dec 2008 16:25:46.635                                                                                  

 

原文鏈接:https://blog.csdn.net/w_wensan/article/details/76513085


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM