時間函式
trunc()
可獲得天、月、年初
SELECT TRUNC(SYSDATE) FROM dual
SELECT TRUNC(SYSDATE,'mm') FROM dual
SELECT TRUNC(SYSDATE,'yyyy') FROM dual
last_day()
獲得月末
SELECT last_day(SYSDATE+30) FROM dual
注意30在括號外和括號內結果不一樣
next_day()
下一個周天,可以是字元也可以是數字,數字1-7分別是週日至週六
SELECT next_day(SYSDATE,'mon') FROM dual
to_char()
把日期轉換成字元
SELECT to_char(SYSDATE,'d') FROM dual
當週第幾天
SELECT to_char(SYSDATE,'dd') FROM dual
日期
SELECT to_char(SYSDATE,'ddd') FROM dual
當年第幾周
add_months()
SELECT add_months(SYSDATE,2) FROM dual
months_between()
SELECT trunc(months_between(SYSDATE,sysdate+32)) FROM dual
各時間函式組合應用可以巧妙解決一些問題:
select count(*)
from ( select rownum-1 rnum
from all_objects
where rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002-
02-01','yyyy-mm-dd')+1
)
where to_char( to_date('2002-02-01','yyyy-mm-dd')+rnum-1, 'D' )
not in ( '1', '7' )
查詢2002-02-28至2002-02-01間除星期一和七的天數
SELECT trunc(sysdate-30+ROWNUM) FROM xiaoling.rbac_domain
可獲得天、月、年初
SELECT TRUNC(SYSDATE) FROM dual
SELECT TRUNC(SYSDATE,'mm') FROM dual
SELECT TRUNC(SYSDATE,'yyyy') FROM dual
last_day()
獲得月末
SELECT last_day(SYSDATE+30) FROM dual
注意30在括號外和括號內結果不一樣
next_day()
下一個周天,可以是字元也可以是數字,數字1-7分別是週日至週六
SELECT next_day(SYSDATE,'mon') FROM dual
to_char()
把日期轉換成字元
SELECT to_char(SYSDATE,'d') FROM dual
當週第幾天
SELECT to_char(SYSDATE,'dd') FROM dual
日期
SELECT to_char(SYSDATE,'ddd') FROM dual
當年第幾周
add_months()
SELECT add_months(SYSDATE,2) FROM dual
months_between()
SELECT trunc(months_between(SYSDATE,sysdate+32)) FROM dual
各時間函式組合應用可以巧妙解決一些問題:
select count(*)
from ( select rownum-1 rnum
from all_objects
where rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002-
02-01','yyyy-mm-dd')+1
)
where to_char( to_date('2002-02-01','yyyy-mm-dd')+rnum-1, 'D' )
not in ( '1', '7' )
查詢2002-02-28至2002-02-01間除星期一和七的天數
SELECT trunc(sysdate-30+ROWNUM) FROM xiaoling.rbac_domain
SELECT to_date('2013-12-23 23:33:22','yyyy-mm-dd hh24:mi:ss')+ROWNUM FROM xiaoling.rbac_domain
生成連續日期
SELECT trunc(to_date('2013-12-23 23:33:22','yyyy-mm-dd hh24:mi:ss')+ROWNUM/1440,'mi') FROM xiaoling.rbac_domain
連續的分鐘
在左關聯時很有用,如
在2015-02-21 12點到15點每分鐘的交易量,並把沒有交易的時間排到最前面
SELECT *
FROM (SELECT TO_DATE('2015-02-21 12', 'yyyy-mm-dd hh24') +
(ROWNUM - 1) / 1440 RECORD_TIME
FROM table_name
WHERE ROWNUM <= 180)
LEFT JOIN
(SELECT TRUNC(TRADE_TIME, 'mi') RECORD_TIME, COUNT(1) CNT
FROM table_name
WHERE TRADE_TIME BETWEEN TO_DATE('2015-02-21 12', 'yyyy-mm-dd hh24') AND
TO_DATE('2015-02-21 15', 'yyyy-mm-dd hh24')
AND TRIM(MCH_NAME) = '安徽省星啟天網路技術有限公司'
AND TRADE_STATE = 2
GROUP BY TRUNC(TRADE_TIME, 'mi'))
USING (RECORD_TIME)
ORDER BY CNT NULLS FIRST, RECORD_TIME
生成連續日期
SELECT trunc(to_date('2013-12-23 23:33:22','yyyy-mm-dd hh24:mi:ss')+ROWNUM/1440,'mi') FROM xiaoling.rbac_domain
連續的分鐘
在左關聯時很有用,如
在2015-02-21 12點到15點每分鐘的交易量,並把沒有交易的時間排到最前面
SELECT *
FROM (SELECT TO_DATE('2015-02-21 12', 'yyyy-mm-dd hh24') +
(ROWNUM - 1) / 1440 RECORD_TIME
FROM table_name
WHERE ROWNUM <= 180)
LEFT JOIN
(SELECT TRUNC(TRADE_TIME, 'mi') RECORD_TIME, COUNT(1) CNT
FROM table_name
WHERE TRADE_TIME BETWEEN TO_DATE('2015-02-21 12', 'yyyy-mm-dd hh24') AND
TO_DATE('2015-02-21 15', 'yyyy-mm-dd hh24')
AND TRIM(MCH_NAME) = '安徽省星啟天網路技術有限公司'
AND TRADE_STATE = 2
GROUP BY TRUNC(TRADE_TIME, 'mi'))
USING (RECORD_TIME)
ORDER BY CNT NULLS FIRST, RECORD_TIME
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/14888950/viewspace-1439701/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- PHP 時間函式PHP函式
- Golang時間函式及測試函式執行時間案例Golang函式
- T-SQL——函式——時間操作函式SQL函式
- Clickhouse 時間日期函式函式
- 時間函式:與時間相關那些事。。。函式
- SPL 的日期時間函式函式
- FreeRTOS-04-核心控制函式+時間管理函式函式
- MySQL 的日期和時間函式MySql函式
- python之為函式執行設定超時時間(允許函式執行的最大時間)Python函式
- 探索MySQL高階語句(數學函式、聚合函式、字串函式、日期時間函式)MySql函式字串
- pandas dataframe 時間欄位 diff 函式函式
- 636. 函式的獨佔時間函式
- Go基礎-時間和日期函式Go函式
- MySQL日期和時間函式彙總MySql函式
- Oracle計算時間函式(對時間的加減numtodsinterval、numtoyminterval)Oracle函式
- PostgreSQL:時間——型別、運算子和函式SQL型別函式
- MySQL 日期函式、時間函式在實際場景中的應用MySql函式
- C時間函式strftime、struct timespec 和 struct timeval函式Struct
- python效能優化之函式執行時間分析Python優化函式
- GO語言————6.11 計算函式執行時間Go函式
- ORACLE中日期和時間函式彙總(轉載)Oracle函式
- hive時間日期函式及典型場景應用Hive函式
- javascript和PHP及MYSQL時間格式化函式JavaScriptPHPMySql函式
- linux系統時間程式設計(6) 日曆時間tm轉字串strftime函式Linux程式設計字串函式
- 延時函式函式
- 何時使用函式表示式與函式宣告函式
- linux系統時間程式設計(9) 計算程式片段執行時間clock函式Linux程式設計函式
- linux下時間有關的函式和結構體Linux函式結構體
- 1026 程式執行時間(四捨五入,round函式)函式
- 使用ASM框架實現統計函式執行時間ASM框架函式
- c++ CopyFile函式響應時間過長問題。C++函式
- PHP陣列函式的時間複雜度清單PHP陣列函式時間複雜度
- 時間函式的簡單理解和應用(time.h)函式
- mysql 時間相關的函式 以及日期和字串互轉MySql函式字串
- 關於 Date 函式獲取各類時間/日期/天數函式
- 函式呼叫與空間分配函式
- 【解惑】時間規劃,Linq的Aggregate函式在計算會議重疊時間中的應用函式
- 課時21:函式:lambda表示式函式
- 關於Android room 時間函式條件的坑 給需要的人AndroidOOM函式