目次
基于年的运算:
基于季度的运算:
基于月的运算:
基于周的运算:
基于天的运算:
综述:

Oracle日期运算,你知多少?

Jun 07, 2016 pm 03:27 PM
oracle 対処する 幾つか 毎日 日付 手術

日常工作对日期处理不多,最近因为需要设计一个时间维表,借这个机会,整理下常用的日期处理运算方法。 Oracle提供了几个基本的日期处理函数 函数 描述 ADD_MONTHS(DATE,COUNT) 指定日期 date上增加 count个月 LAST_DAY(DATE) 返回日期 date所在月的最后一天

日常工作对日期处理不多,最近因为需要设计一个时间维表,借这个机会,整理下常用的日期处理运算方法。

Oracle提供了几个基本的日期处理函数

函数

描述

ADD_MONTHS(DATE,COUNT)

指定日期date上增加count个月

LAST_DAY(DATE)

返回日期date所在月的最后一天

MONTHS_BETWEEN(DATE1,DATE2)

返回相差多少个月

NEW_TIME(DATE,’THIS’,’OTHER’)

将时间从this时区转换到other时区

NEXT_DAY(DATE,’DAY’)

返回指定日期或之后的第一个星期几的日期,’day’为星期几,也可以为1-7的数字,1代表星期日,以此类推

SYSDATE

获取系统当前日期至

CURRENT_TIMESTAMP()

当前时间和日期值

示例代码:

select add_months(sysdate,2)                                 as "两个月后的日期",
  last_day(sysdate)                                          as "本月最后一天",
  months_between(sysdate, to_date('2012-12-20','yyyy-mm-dd'))as "月份差",
  new_time(sysdate,'CST','EST')                              as "北京时间转换为东部时间",
  next_day(sysdate,1)                                        as "下个周日的日期",
  sysdate                                                    as "当前系统时间"
from dual
ログイン後にコピー

返回结果:

两个月后的日期

8/27/2012 15:56

本月最后一天

6/30/2012 15:56

月份差

-5.752772177

北京时间转换为东部时间

6/27/2012 16:56

下个周日的日期

7/1/2012 15:56

当前系统时间

6/27/2012 15:56

 

事实上,往往令人头疼是那些基于时间单位的计算,如年(Year),季(Quarter),月(Month),周(Week),天(Day),时(Hour),分(Minute),秒(Second),毫秒(Millisecond)。(毫秒暂不讨论)

得到各单位的时间,我们通常有两种方法:

例:

TRUNC(SYSDATE,’MI’) 得到精确至‘分’的日期时间
TO_CHAR(SYSDATE,’MI’) 获取时间的‘分’的值

 

基于年的运算:

--得到一年的第一天
select trunc(sysdate,'y') from dual;
--得到一年的最后一天
select add_months(trunc(sysdate,'yyyy'),12) -1 from dual;
--得到一年的每一天
select trunc(sysdate,'yyyy') + rn -1 date0
 from (select rownum rn from all_objects where rownum 
<p><br>
</p>
<h2 id="基于季度的运算">基于季度的运算:</h2>
<p></p><pre class="brush:php;toolbar:false">--本季度第一天
select to_char(trunc(sysdate,'q'),'yyyy-mm-dd') from dual;
--本季度最后一天
select add_months(trunc(sysdate,'q'),3) -1 from dual;
--上个季度最后一天(可以用本季度第一天减去1得到)
select to_char(trunc(sysdate,'q') -1,'yyyy-mm-dd') from dual;
--上个季度第一天(本季度第一天减 3个月)
select to_char(add_months(trunc(sysdate,'q'), -3),'yyyy-mm-dd')
 from dual;
--上个季度第一天(本季度减一个月之后的月份的最后一天)
select to_char(last_day(add_months(trunc(sysdate,'q'), -1)),'yyyy-mm-dd')
 from dual;
ログイン後にコピー

基于月的运算:

--得到月份
select to_char(sysdate,'month') from dual;
--得到第几月
select to_char(sysdate,'mm') from dual;
--该月第一天
select trunc(sysdate,'mm') from dual;
--该月最后一天
select last_day(trunc(sysdate)) from dual;
--当前月份的第几天
select to_char(sysdate,'dd') from dual;
ログイン後にコピー

基于周的运算:

--一周的第一天
select to_char(sysdate,'d') from dual;
--得到星期几
select initcap(to_char(sysdate,'day')) from dual;
--取当前时间是一年中的第几周(按实际日历的)
select to_char(sysdate,'iw') from dual;
---取当前时间是一年中的第几周(从1.1开始算)
select to_char(sysdate,'ww') from dual;
--取当前时间是一个月中的第几周(从1日开始算)
select to_char(sysdate,'w') from dual;
--本周第一天(星期天算起)
selecttrunc(sysdate,'d') from dual;
--本周最后一天(星期天算起)
select trunc(sysdate,'d') +6 from dual;
ログイン後にコピー

基于天的运算:

--获取前一天的开始时间和结束时间
select to_char(to_date(to_char(sysdate - 1,'yyyy-mm-dd'),'yyyy-mm-dd'),
              'yyyy-mm-dd hh24:mi:ss')
 from dual;
 
select to_char(to_date(to_char(sysdate,'yyyy-mm-dd'),'yyyy-mm-dd'),
              'yyyy-mm-dd hh24:mi:ss')
 from dual;
ログイン後にコピー

综述:

举例就到此为止了,多数的运算已经罗列出来,如有其他需求,可以尝试以上的方法来引申。

欢迎大家一起学习交流!

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Oracleで2つの日付の間の日数を計算する関数 Oracleで2つの日付の間の日数を計算する関数 May 08, 2024 pm 07:45 PM

2 つの日付の間の日数を計算する Oracle の関数は DATEDIFF() です。具体的な使用法は次のとおりです。 時間間隔の単位を指定します: 間隔 (日、月、年など) 2 つの日付値を指定します: date1 と date2DATEDIFF(interval, date1, date2) 日数の差を返します。

Oracle データベースのログはどのくらいの期間保存されますか? Oracle データベースのログはどのくらいの期間保存されますか? May 10, 2024 am 03:27 AM

Oracle データベース ログの保存期間は、次のようなログのタイプと構成によって異なります。 REDO ログ: 「LOG_ARCHIVE_DEST」パラメータで構成された最大サイズによって決定されます。アーカイブ REDO ログ: 「DB_RECOVERY_FILE_DEST_SIZE」パラメータで構成された最大サイズによって決まります。オンライン REDO ログ: アーカイブされず、データベースの再起動時に失われます。保持期間はインスタンスの実行時間と一致します。監査ログ: 「AUDIT_TRAIL」パラメータによって構成され、デフォルトで 30 日間保持されます。

Oracle データベースの起動手順の順序は次のとおりです。 Oracle データベースの起動手順の順序は次のとおりです。 May 10, 2024 am 01:48 AM

Oracle データベースの起動シーケンスは次のとおりです。 1. 前提条件を確認します。 3. データベース インスタンスを起動します。 5. データベースに接続します。サービスを有効にします (必要な場合)。 8. 接続をテストします。

オラクルで間隔を使用する方法 オラクルで間隔を使用する方法 May 08, 2024 pm 07:54 PM

Oracle の INTERVAL データ型は、時間間隔を表すために使用されます。構文は INTERVAL <precision> <unit> です。INTERVAL の演算には、加算、減算、乗算、除算を使用できます。これは、時間データの保存などのシナリオに適しています。日付の差を計算します。

oracle に 2 つの文字列が含まれているかどうかを判断する方法 oracle に 2 つの文字列が含まれているかどうかを判断する方法 May 08, 2024 pm 07:00 PM

Oracle では、ネストされた INSTR 関数を使用して、文字列に 2 つの部分文字列が同時に含まれているかどうかを判断できます。INSTR(string1, string2a) が 0 より大きく、INSTR(string1, string2b) が 0 より大きい場合、それは含まれます。それ以外の場合は含まれません。

Oracle で特定の文字の出現数を確認する方法 Oracle で特定の文字の出現数を確認する方法 May 09, 2024 pm 09:33 PM

Oracle で文字の出現数を確認するには、次の手順を実行します。 文字列の全長を取得します。 文字が出現する部分文字列の長さを取得します。 部分文字列の長さを減算して、文字の出現数をカウントします。全長から。

Oracle データベース サーバーのハードウェア構成要件 Oracle データベース サーバーのハードウェア構成要件 May 10, 2024 am 04:00 AM

Oracle データベース サーバーのハードウェア構成要件: プロセッサ: マルチコア、少なくとも 2.5 GHz のメイン周波数 大規模なデータベースの場合は、32 コア以上が推奨されます。メモリ: 小規模データベースの場合は少なくとも 8 GB、中規模のデータベースの場合は 16 ~ 64 GB、大規模なデータベースまたは重いワークロードの場合は最大 512 GB 以上。ストレージ: SSD または NVMe ディスク、冗長性とパフォーマンスのための RAID アレイ。ネットワーク: 高速ネットワーク (10GbE 以上)、専用ネットワーク カード、低遅延ネットワーク。その他: 安定した電源、冗長コンポーネント、互換性のあるオペレーティング システムとソフトウェア、放熱と冷却システム。

Oracle にはどれくらいのメモリが必要ですか? Oracle にはどれくらいのメモリが必要ですか? May 10, 2024 am 04:12 AM

Oracle が必要とするメモリーの量は、データベースのサイズ、アクティビティー・レベル、および必要なパフォーマンス・レベル (データ・バッファー、索引バッファーの保管、SQL ステートメントの実行、およびデータ・ディクショナリー・キャッシュの管理) によって異なります。正確な量は、データベースのサイズ、アクティビティ レベル、および必要なパフォーマンス レベルによって影響されます。ベスト プラクティスには、適切な SGA サイズの設定、SGA コンポーネントのサイズ設定、AMM の使用、メモリ使用量の監視などが含まれます。

See all articles