-- 語句級一致性事務或讀已提交事務(默認)
set transaction isolation read committed;
-- 只讀事務
set transaction read only;
-- 事務級一致性事務或順序事務
set transaction isolation level serializable;
-- 設置該事務使用一個回退段
set transaction use rollback segment rollback_segment_name;
-- 提交事務
commit;
-- 更改日期格式
alter session set nls_date_format = 'yyyy-mm-dd hh24:mi:ss';
-- 查詢當前數據庫的日期時間
SQL> select sysdate " 看看能有多精準 " from dual;
看看能有多精準
----------------------
2008-11-17 14:59:45
-- 查詢當前會話的日期
SQL> select current_date " 當前日期 " from dual;
當前日期
--------------------
2008-11-17 11:53:20
-- 查詢當前會話的日期時間,帶精度.精度範圍爲0~9,默認是6. CURRENT_TIMESTAMP[(d)]
SQL> select current_timestamp(6) from dual;
CURRENT_TIMESTAMP(6)
--------------------------------------------------------------------------------
17-11月-08 11.52.11.676615 上午 +08:00
-- 查詢日期時間d中指定的部分c. EXTRACT(c, FROM d)
SQL> select sysdate " 當前日期 ", extract(year from sysdate) year, extract(month from sysdate) month, extract(day from sysdate) day from dual;
當前日期 YEAR MONTH DAY
-------------------- ---------- ---------- ----------
2008-11-17 12:02:02 2008 11 17
-- 查詢日期d所在月份的最後一天
SQL> select last_day(sysdate) lastDay from dual;
LASTDAY
-----------
2008-11-30
-- 查詢當前會話時區的日期時間.帶精度.精度範圍爲0~9,默認是6. LOCALTIMESTAMP[(d)]
SQL> select localtimestamp(6) from dual;
LOCALTIMESTAMP(6)
--------------------------------------------------------------------------------
17-11月-08 02.30.55.921204 下午
-- 查詢日期d1和d2之間相差的月數. 如果d1<d2,返回負值; 如果d1和d2天數相同或都是月底,則返回整數; 否則Oracle以每月31天計算結果的小數部分.
SQL> select months_between(sysdate, sysdate-31) "相差月數" from dual;
相差月數
----------
1
-- 查詢日期d後下一個c.c是字符串,表示當前會話語言表示的一週的某一天的全稱.
SQL> select sysdate 當前日期, next_day(sysdate, '星期日') 新日期 from dual;
當前日期 新日期
----------- -----------
2008-11-17 2008-11-23
-- 對日期進行四捨五入
SQL> select sysdate 當前日期, round(sysdate, 'day') 處理後的日, round(sysdate, 'month') 處理後的月, round(sysdate, 'year') 處理後的年 from dual;
當前日期 處理後的日 處理後的月 處理後的年
----------- ----------- ----------- -----------
2008-11-17 2008-11-16 2008-12-1 2009-1-1
-- 對日期進行截斷
SQL> select sysdate 當前日期, trunc(sysdate, 'year') 處理後的年, trunc(sysdate, 'month') 處理後的月, trunc(sysdate, 'day') 處理後的日 from dual;
當前日期 處理後的年 處理後的月 處理後的日
----------- ----------- ----------- -----------
2008-11-17 2008-1-1 2008-11-1 2008-11-16
-- 查詢數據庫時區偏移量
SQL> select sessiontimezone from dual;
SESSIONTIMEZONE
---------------------------------------------------------------------------
+08:00
-- 查詢數據庫所在的時區
SQL> select dbtimezone from dual;
DBTIMEZONE
----------
+08:00
-- 查詢時區名tz指定的時區與格林尼治相比的時區偏差
SQL> select tz_offset(dbtimezone), tz_offset('Europe/London') from dual;
TZ_OFFSET(DBTIMEZONE) TZ_OFFSET('EUROPE/LONDON')
--------------------- --------------------------
+08:00 +00:00
-- 返回當前數據庫的一個TIMESTAMP WITH TIME ZONE類型的日期時間
SQL> select systimestamp from dual;
SYSTIMESTAMP
--------------------------------------------------------------------------------
17-11月-08 02.56.13.115110 下午 +08:00
-- 將字符串c轉變爲ascii字符串. ASCIISTR(c)
SQL> select asciistr('abc#中國*ABC') from dual;
ASCIISTR('ABC#中國*ABC')
------------------------
abc#\4E2D\56FD*ABC
-- 將二進制轉爲十進制. BIN_TO_NUM(n1, n2, n3, ...)
SQL> select bin_to_num(1, 1, 0, 1) from dual;
BIN_TO_NUM(1,1,0,1)
-------------------
13
-- 將表達式c轉換爲數據類型t.
SQL> select sysdate, cast(sysdate as varchar2(25)) from dual;
SYSDATE CAST(SYSDATEASVARCHAR2(25))
----------- ---------------------------
2008-11-17 17-11月-08
-- 把數字n轉化成c指定的INTERVAL DAY TO SECOND類型的數據
SQL> select sysdate " 當前時間 ", sysdate + numtodsinterval(30, 'minute') " 30分鐘後 ", sysdate + numtodsinterval(2, 'hour') " 兩小時後 "from dual;
當前時間 30分鐘後 兩小時後
---------------- ---------------- ----------------
2008-11-17 15:51 2008-11-17 16:21 2008-11-17 17:51
-- 把數字n轉化爲c指定的INTERVAL YEAR TO SECOND類型的數據
SQL> select sysdate " 當前時間 ", sysdate + numtoyminterval(2, 'year') " 2年後 ", sysdate + numtoyminterval(6, 'month') " 6個月後 " from dual;
當前時間 2年後 6個月後
---------------- ------------- ---------------
2008-11-17 16:07 2010-11-17 16 2009-5-17 16:07
-- 返回將x按fmt格式轉化後的字符串. TO_CAHR(x[, fmt])
SQL> select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') 當前時間 from dual;
當前時間
-------------------
2008-11-17 04:12:16
SQL> select to_char(123.456, '9.99EEEE') num1, to_char(123.456, '9999.90') from dual;
NUM1 TO_CHAR(123.456,'9999.90')
---------- --------------------------
1.23E+02 123.46
-- 將符合fmt指定的特定日期格式的字符串c轉化成DATE類型的數據
SQL> select to_date('20-11月-2008', 'dd-mon-yyyy') 當前時間 from dual;
當前時間
-----------------------------
2008-11-20
-- 將符合特定格式的字符串轉化成INTERVAL DAY TO SECOND類型的數據
SQL> select sysdate " 當前時間 ", sysdate + to_dsinterval('030 12:00:00') " 30.5天后 " from dual;
當前時間 30.5天后
-------------------- ------------------
2008-11-17 16:45:38 2008-12-18 4:45:38
-- 將符合fmt指定的數字格式的字符串c轉化成數字類型的數據
SQL> select to_number('RMB1234567.89', 'L99999999D99') 金額 from dual;
金額
----------
1234567.89
-- 返回字符串c對應的UNICODE字符
SQL> select unistr('\00D6') unicode_1, unistr('ca\00D6on') unicode_2 from dual;
UNICODE_1 UNICODE_2
--------- ----------
Ö caÖon
-- 返回e1, e2, e3, ..., en中最大的數. 以e1的數據類型爲準. GREATEST(e1, e2, ..., en)
SQL> select greatest('101', 10, 100) from dual;
GREATEST('101',10,100)
----------------------
101
-- NVL(a, b): 當a是NULL, 則返回b, 否則返回a
SQL> select nvl(null, 0), nvl('null', 0), nvl(null, null) from dual;
NVL(NULL,0) NVL('NULL',0) NVL(NULL,NULL)
----------- ------------- --------------
0 null
-- NVL2(a, b, c): 當a不是NULL, 則返回b, 否則返回c
SQL> select nvl2(null, 'b', 3), nvl2('a', 'b', 'c') from dual;
NVL2(NULL,'B',3) NVL2('A','B','C')
---------------- -----------------
3 b
Oracle的一些關於時間的函數
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.