a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > Oracle > 正文

Oracle查詢優化日期運算實例詳解

2024-08-29 14:00:08
字體:
來源:轉載
供稿:網友

 加減日、月、年

在Oracle中,date類型可以直接加減天數,而加減月份要用add_months函數.

select a.hiredate 雇用日期,    a.hiredate + 5 加5天,    a.hiredate - 5 減5天,    add_months(hiredate, 5) 加5個月,    add_months(hiredate, -5) 減5個月,    add_months(hiredate, 5 * 12) 加5年,    add_months(hiredate, -5 * 12) 減5年 from emp a where rownum <=1;雇用日期 加5天 減5天 加5個月 減5個月 加5年 減5年----------- ----------- ----------- ----------- ----------- ----------- -----------1980-12-17 1980-12-22 1980-12-12 1981-05-17 1980-07-17 1985-12-17 1975-12-17

加減時、分、秒

上面講過,date可以直接加減天數,那么1/24就是一小時,分鐘與秒的加減類同。

select a.hiredate,    a.hiredate - 5 / 24 / 60 / 60 減5秒,    a.hiredate + 5 / 24 / 60 / 60 加5秒,    a.hiredate - 5 / 24 / 60 減5分鐘,    a.hiredate + 5 / 24 / 60 加5分鐘,    a.hiredate - 5 / 24 減5小時,    a.hiredate + 5 / 24 加5小時 from emp a where rownum <= 1;

如果執行時,報錯

Oracle查詢優化日期運算,Oracle,日期運算

數據庫服務器端的編碼和客戶端字符集編碼不一致。

我這邊用的數據庫西班牙語,不支持中文。

日期間隔之時、分、秒

SQL> select duration,    duration * 24 間隔小時,    duration * 24 * 60 間隔分鐘,    duration * 24 * 60 * 60 間隔秒 from (select (max(a.hiredate) - min(a.hiredate)) as duration from emp a where    a.ename in ('ALLEN', 'WARD')) x; DURATION    間隔小時    間隔分鐘    間隔秒---------- ---------- ---------- ----------     2     48    2880   172800

日期間隔之日、月、年

加減月份用函數 add_months, 而計算月份間隔就要用函數months_between

select max_hd - min_hd 間隔天,    months_between(max_hd, min_hd) 間隔月,    months_between(max_hd, min_hd) /12 間隔年 from (select min(hiredate) min_hd, max(hiredate) max_hd from emp) x;    間隔天    間隔月    間隔年---------- ---------- ----------   2348 77.1935483 6.43279569

計算一年中周內各日期的次數

問題

計算一年中周內各日期(星期日、星期一 ……星期六)的次數。

解決方案

要計算一年中周內各日期分別有多少個,必須:

  1. 生成一年內的所有日期。
  2. 設置日期格式,得到每個日期對應為星期幾。
  3. 計數周內各日期分別有多少個。
with x as (select level lvl  from dual connect by level <=       (add_months(trunc(sysdate, 'y'), 12) - trunc(sysdate, 'y')))select to_char(trunc(sysdate, 'y') + lvl - 1, 'DAY'), count(*) from x group by to_char(trunc(sysdate, 'y') + lvl - 1, 'DAY');

Oracle查詢優化日期運算,Oracle,日期運算

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 99久久精品久久亚洲精品 | av免费网站| 久久com| 色婷婷综合久久久久中文一区二区 | 日韩欧美在线播放 | 日本视频黄 | 免费v片| 国产欧美亚洲精品 | www.超碰| www四虎| 欧美日韩综合视频 | 精品国产一区二区三区久久影院 | 久久精品1区2区 | 日韩欧美视频 | 久久精品国产一区 | 久久一区| 国产精品美女久久久久久久网站 | 成人网址在线观看 | 亚洲 成人 av | 成人在线视频网 | 黄色毛片在线观看 | 色综合一区二区三区 | 国产欧美久久一区二区三区 | 久久久久亚洲一区二区三区 | 午夜老湿影院 | 老司机深夜福利在线观看 | 综合精品久久久 | 久久久久久久久综合 | 99久久精品免费看国产免费软件 | 亚洲精选免费视频 | 久久av资源网 | 欧美日韩国产高清视频 | 国产精品久久久久久吹潮 | 国产伦精品久久久一区二区三区 | www.超碰| 亚洲自拍一区在线 | 国产第一页在线播放 | 一级片在线免费看 | 国产精品资源 | 日本久久久久久久久久 | 欧美14一18处毛片 |