亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Oracle關(guān)于時間/日期的操作

 更新時間:2007年03月21日 00:00:00   作者:  
在oracle中有很多關(guān)于日期的函數(shù),如:

  1、add_months()用于從一個日期值增加或減少一些月份

  date_value:=add_months(date_value,number_of_months)

  例:

  SQL> select add_months(sysdate,12) "Next Year" from dual;

  Next Year

  ----------

  13-11月-04

  SQL> select add_months(sysdate,112) "Last Year" from dual;

  Last Year

  ----------

  13-3月 -13

 

  SQL>

  2、current_date()返回當(dāng)前會放時區(qū)中的當(dāng)前日期

  date_value:=current_date

  SQL> column sessiontimezone for a15

  SQL> select sessiontimezone,current_date from dual;

  SESSIONTIMEZONE CURRENT_DA

  --------------- ----------

  +08:00 13-11月-03

  SQL> alter session set time_zone='-11:00'

  2 /

  會話已更改。

  SQL> select sessiontimezone,current_timestamp from dual;

  SESSIONTIMEZONE CURRENT_TIMESTAMP

  --------------- ------------------------------------

  -11:00 12-11月-03 04.59.13.668000 下午 -11:

  00

  SQL>

  3、current_timestamp()以timestamp with time zone數(shù)據(jù)類型返回當(dāng)前會放時區(qū)中的當(dāng)前日期

  timestamp_with_time_zone_value:=current_timestamp([timestamp_precision])

  SQL> column sessiontimezone for a15

  SQL> column current_timestamp format a36

  SQL> select sessiontimezone,current_timestamp from dual;

  SESSIONTIMEZONE CURRENT_TIMESTAMP

  --------------- ------------------------------------

  +08:00 13-11月-03 11.56.28.160000 上午 +08:

  00

  SQL> alter session set time_zone='-11:00'

  2 /

  會話已更改。

  SQL> select sessiontimezone,current_timestamp from dual;

  SESSIONTIMEZONE CURRENT_TIMESTAMP

  --------------- ------------------------------------

  -11:00 12-11月-03 04.58.00.243000 下午 -11:

  00

  SQL>

  4、dbtimezone()返回時區(qū)

  varchar_value:=dbtimezone

  SQL> select dbtimezone from dual;

  DBTIME

  ------

  -07:00

  SQL>

  5、extract()找出日期或間隔值的字段值

  date_value:=extract(date_field from [datetime_value|interval_value])

  SQL> select extract(month from sysdate) "This Month" from dual;

  This Month

  ----------

  11

  SQL> select extract(year from add_months(sysdate,36)) "3 Years Out" from dual;

  3 Years Out

  -----------

  2006

  SQL>

  6、last_day()返回包含了日期參數(shù)的月份的最后一天的日期

  date_value:=last_day(date_value)

  SQL> select last_day(date'2000-02-01') "Leap Yr?" from dual;

  Leap Yr?

  ----------

  29-2月 -00

  SQL> select last_day(sysdate) "Last day of this month" from dual;

  Last day o

  ----------

  30-11月-03

  SQL>

  7、localtimestamp()返回會話中的日期和時間

  timestamp_value:=localtimestamp

  SQL> column localtimestamp format a28

  SQL> select localtimestamp from dual;

  LOCALTIMESTAMP

  ----------------------------

  13-11月-03 12.09.15.433000

  下午

  SQL> select localtimestamp,current_timestamp from dual;

  LOCALTIMESTAMP CURRENT_TIMESTAMP

  ---------------------------- ------------------------------------

  13-11月-03 12.09.31.006000 13-11月-03 12.09.31.006000 下午 +08:

  下午 00

  SQL> alter session set time_zone='-11:00';

  會話已更改。

  SQL> select localtimestamp,to_char(sysdate,'DD-MM-YYYY HH:MI:SS AM') "SYSDATE" from dual;

  LOCALTIMESTAMP SYSDATE

  ---------------------------- ------------------------

  12-11月-03 05.11.31.259000 13-11-2003 12:11:31 下午

  下午

  SQL>

  8、months_between()判斷兩個日期之間的月份數(shù)量

  number_value:=months_between(date_value,date_value)

  SQL> select months_between(sysdate,date'1971-05-18') from dual;

  MONTHS_BETWEEN(SYSDATE,DATE'1971-05-18')

  ----------------------------------------

  389.855143

  SQL> select months_between(sysdate,date'2001-01-01') from dual;

  MONTHS_BETWEEN(SYSDATE,DATE'2001-01-01')

  ----------------------------------------

  34.4035409

  SQL>

  9、next_day()給定一個日期值,返回由第二個參數(shù)指出的日子第一次出現(xiàn)在的日期值(應(yīng)返回相應(yīng)日子的名稱字符串)

  說明:

  單行日期函數(shù)

  單行日期函數(shù)操作data數(shù)據(jù)類型,絕大多數(shù)都有data數(shù)據(jù)類型的參數(shù),絕大多數(shù)返回的也是data數(shù)據(jù)類型的值。

  10、add_months(,)

  返回日期d加上i個月后的結(jié)果。i可以使任意整數(shù)。如果i是一個小數(shù),那么數(shù)據(jù)庫將隱式的他轉(zhuǎn)換成整數(shù),將會截去小數(shù)點后面的部分。

  11、last_day()

  函數(shù)返回包含日期d的月份的最后一天

  12、months_between(,)

  返回d1和d2之間月的數(shù)目,如果d1和d2的日的日期都相同,或者都使該月的最后一天,那么將返回一個整數(shù),否則會返回的結(jié)果將包含一個分?jǐn)?shù)。

  13、new_time(,,)

  d1是一個日期數(shù)據(jù)類型,當(dāng)時區(qū)tz1中的日期和時間是d時,返回時區(qū)tz2中的日期和時間。tz1和tz2時字符串。

  14、next_day(,)

  返回日期d后由dow給出的條件的第一天,dow使用當(dāng)前會話中給出的語言指定了一周中的某一天,返回的時間分量與d的時間分量相同。

  select next_day(''01-jan-2000'',''monday'') "1st monday",next_day(''01-nov-2004'',''tuesday'')+7 "2nd tuesday") from dual;1st monday 2nd tuesday03-jan-2000 09-nov-2004

  15、round([,])

  將日期d按照fmt指定的格式舍入,fmt為字符串。

  16、syadate

  函數(shù)沒有參數(shù),返回當(dāng)前日期和時間。

  17、trunc([,])

  返回由fmt指定的單位的日期d.

  單行轉(zhuǎn)換函數(shù)

  單行轉(zhuǎn)換函數(shù)用于操作多數(shù)據(jù)類型,在數(shù)據(jù)類型之間進(jìn)行轉(zhuǎn)換。

  18、chartorwid()

  c 使一個字符串,函數(shù)將c轉(zhuǎn)換為rwid數(shù)據(jù)類型。

  select test_id from test_case where rowid=chartorwid(''aaaa0saacaaaaliaaa'')

  19、convert(,[,])

  c尾字符串,dset、sset是兩個字符集,函數(shù)將字符串c由sset字符集轉(zhuǎn)換為dset字符集,sset的缺省設(shè)置為數(shù)據(jù)庫的字符集。

  20、hextoraw()

  x為16進(jìn)制的字符串,函數(shù)將16進(jìn)制的x轉(zhuǎn)換為raw數(shù)據(jù)類型。

  21、rawtohex()

  x是raw數(shù)據(jù)類型字符串,函數(shù)將raw數(shù)據(jù)類轉(zhuǎn)換為16進(jìn)制的數(shù)據(jù)類型。

  22、rowidtochar()

  函數(shù)將rowid數(shù)據(jù)類型轉(zhuǎn)換為char數(shù)據(jù)類型。

  23、to_char([[,)

  x是一個data或number數(shù)據(jù)類型,函數(shù)將x轉(zhuǎn)換成fmt指定格式的char數(shù)據(jù)類型,如果x為日期nlsparm=nls_date_language 控制返回的月份和日份所使用的語言。如果x為數(shù)字nlsparm=nls_numeric_characters 用來指定小數(shù)位和千分位的分隔符,以及貨幣符號。

  nls_numeric_characters ="dg", nls_currency="string"

  24、to_date([,[,)

  c表示字符串,fmt表示一種特殊格式的字符串。返回按照fmt格式顯示的c,nlsparm表示使用的語言。函數(shù)將字符串c轉(zhuǎn)換成date數(shù)據(jù)類型。

  25、to_multi_byte()

  c表示一個字符串,函數(shù)將c的擔(dān)子截字符轉(zhuǎn)換成多字節(jié)字符。

  26、to_number([,[,)

  c表示字符串,fmt表示一個特殊格式的字符串,函數(shù)返回值按照fmt指定的格式顯示。nlsparm表示語言,函數(shù)將返回c代表的數(shù)字。

  27、to_single_byte()

  將字符串c中得多字節(jié)字符轉(zhuǎn)化成等價的單字節(jié)字符。該函數(shù)僅當(dāng)數(shù)據(jù)庫字符集同時包含單字節(jié)和多字節(jié)字符時才使用。

 

  1.日期時間間隔操作

  當(dāng)前時間減去7分鐘的時間

  select sysdate,sysdate - interval '7' MINUTE from dual

  當(dāng)前時間減去7小時的時間

  select sysdate - interval '7' hour from dual

  當(dāng)前時間減去7天的時間

  select sysdate - interval '7' day from dual

  當(dāng)前時間減去7月的時間

  select sysdate,sysdate - interval '7' month from dual

  當(dāng)前時間減去7年的時間

  select sysdate,sysdate - interval '7' year from dual

  時間間隔乘以一個數(shù)字

  select sysdate,sysdate - 8 *interval '2' hour from dual

  2.日期到字符操作

  select sysdate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual

  select sysdate,to_char(sysdate,'yyyy-mm-dd hh:mi:ss') from dual

  select sysdate,to_char(sysdate,'yyyy-ddd hh:mi:ss') from dual

  select sysdate,to_char(sysdate,'yyyy-mm iw-d hh:mi:ss') from dual

  參考o(jì)racle的相關(guān)關(guān)文檔(ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4.HTM#48515)

  3. 字符到日期操作

  select to_date('2003-10-17 21:15:37','yyyy-mm-dd hh24:mi:ss') from dual

  具體用法和上面的to_char差不多。

  4. trunk/ ROUND函數(shù)的使用

  select trunc(sysdate ,'YEAR') from dual

  select trunc(sysdate ) from dual

  select to_char(trunc(sysdate ,'YYYY'),'YYYY') from dual

  5.oracle有毫秒級的數(shù)據(jù)類型

  --返回當(dāng)前時間 年月日小時分秒毫秒

  select to_char(current_timestamp(5),'DD-MON-YYYY HH24:MI:SSxFF') from dual;

  --返回當(dāng)前 時間的秒毫秒,可以指定秒后面的精度(最大=9)

  select to_char(current_timestamp(9),'MI:SSxFF') from dual;

  6.計算程序運行的時間(ms)

  declare

  type rc is ref cursor;

  l_rc rc;

  l_dummy all_objects.object_name%type;

  l_start number default dbms_utility.get_time;

  begin

  for I in 1 .. 1000

  loop

  open l_rc for

  'select object_name from all_objects '||

  'where object_id = ' || i;

  fetch l_rc into l_dummy;

  close l_rc;

  end loop;

  dbms_output.put_line

  ( round( (dbms_utility.get_time-l_start)/100, 2 ) ||

  ' seconds...' );

  end;

相關(guān)文章

  • Oracle 表空間查詢與操作方法

    Oracle 表空間查詢與操作方法

    本文將介紹Oracle 表空間查詢與操作方法,需要了解跟多的朋友可以參考下
    2012-11-11
  • Oracle?system/用戶被鎖定的解決方法

    Oracle?system/用戶被鎖定的解決方法

    很多人對oracle數(shù)據(jù)庫會將用戶鎖定感覺莫名其妙,所以下面這篇文章主要介紹了Oracle?system/用戶被鎖定的解決方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • oracle區(qū)管理和段空間管理詳細(xì)介紹

    oracle區(qū)管理和段空間管理詳細(xì)介紹

    本文將詳細(xì)介紹oracle區(qū)管理和段空間管理,需要的朋友可以參考下
    2012-11-11
  • 深入sql oracle遞歸查詢

    深入sql oracle遞歸查詢

    本篇文章是對sql oracle 遞歸查詢進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 與虛擬機(jī)Oracle連接出現(xiàn)ora-12154問題的解決方法

    與虛擬機(jī)Oracle連接出現(xiàn)ora-12154問題的解決方法

    這篇文章主要介紹了與虛擬機(jī)Oracle連接出現(xiàn)ora-12154問題的解決方法,需要的朋友可以參考下
    2017-03-03
  • Oracle數(shù)據(jù)庫scott用戶創(chuàng)建view視圖權(quán)限的操作方法

    Oracle數(shù)據(jù)庫scott用戶創(chuàng)建view視圖權(quán)限的操作方法

    這篇文章主要介紹了Oracle數(shù)據(jù)庫scott用戶創(chuàng)建view視圖權(quán)限的操作方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • oracle數(shù)據(jù)庫查看鎖表的sql語句整理

    oracle數(shù)據(jù)庫查看鎖表的sql語句整理

    Oracle數(shù)據(jù)庫操作中,我們有時會用到鎖表查詢以及解鎖和kill進(jìn)程等操作,這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫查看鎖表的sql語句的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • oracle數(shù)據(jù)庫去除重復(fù)數(shù)據(jù)常用的方法總結(jié)

    oracle數(shù)據(jù)庫去除重復(fù)數(shù)據(jù)常用的方法總結(jié)

    數(shù)據(jù)清理的時候常常會清除表中的重復(fù)的數(shù)據(jù),那么在oracle中怎么處理呢?下面這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫去除重復(fù)數(shù)據(jù)常用的方法,需要的朋友可以參考下
    2022-05-05
  • Oracle新增字段和注釋代碼示例

    Oracle新增字段和注釋代碼示例

    Oracle數(shù)據(jù)庫中給字段添加注釋是非常有用的,在我們對數(shù)據(jù)庫進(jìn)行分析和維護(hù)時,通過字段注釋可以更容易地了解這些字段的含義,這篇文章主要給大家介紹了關(guān)于Oracle新增字段和注釋的相關(guān)資料,需要的朋友可以參考下
    2023-09-09
  • Oracle重建控制文件的實例教程

    Oracle重建控制文件的實例教程

    前些天在做Oracle數(shù)據(jù)庫恢復(fù)測試時,因為一些異常操作導(dǎo)致控制文件出了問題,數(shù)據(jù)庫無法正常使用,下面這篇文章就來給大家介紹了關(guān)于Oracle重建控制文件的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧
    2018-05-05

最新評論