Oracle中日期方面的SQL实例

№1:取得当前日期是本月的第几周

SQL> select to_char(sysdate,'YYYYMMDD W HH24:MI:SS') from dual;

TO_CHAR(SYSDATE,'YY
-------------------
20030327 4 18:16:09

SQL> select to_char(sysdate,'W') from dual;

T
-
4

№2:取得当前日期是一个星期中的第几天,注意星期日是第一天

SQL> select sysdate,to_char(sysdate,'D') from dual;

SYSDATE T
--------- -
27-MAR-03 5

类似:

select to_char(sysdate,'yyyy') from dual; --年
select to_char(sysdate,'Q' from dual; --季
select to_char(sysdate,'mm') from dual; --月
select to_char(sysdate,'dd') from dual; --日
ddd 年中的第几天
WW 年中的第几个星期
W 该月中第几个星期
D 周中的星期几
hh 小时(12)
hh24 小时(24)
Mi 分
ss 秒

№3:取当前日期是星期几中文显示:

SQL> select to_char(sysdate,'day') from dual;

TO_CHAR(SYSDATE,'DAY')
----------------------
星期四

№4:如果一个表在一个date类型的字段上面建立了索引,如何使用

alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'

№5: 得到当前的日期
select sysdate from dual;

№6: 得到当天凌晨0点0分0秒的日期
select trunc(sysdate) from dual;

-- 得到这天的最后一秒
select trunc(sysdate) + 0.99999 from dual;

-- 得到小时的具体数值
select trunc(sysdate) + 1/24 from dual;

select trunc(sysdate) + 7/24 from dual;

№7:得到明天凌晨0点0分0秒的日期

select trunc(sysdate+1) from dual;

select trunc(sysdate)+1 from dual;

№8: 本月一日的日期
select trunc(sysdate,'mm') from dual;

№9:得到下月一日的日期
select trunc(add_months(sysdate,1),'mm') from dual;

№10:返回当前月的最后一天
select last_day(sysdate) from dual;
select last_day(trunc(sysdate)) from dual;
select trunc(last_day(sysdate)) from dual;
select trunc(add_months(sysdate,1),'mm') - 1 from dual;

№11: 得到一年的每一天
select trunc(sysdate,'yyyy')+ rn -1 date0
from
(select rownum rn from all_objects
where rownum<366);

№12:今天是今年的第N天
SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;

№13:如何在给现有的日期加上2年
select add_months(sysdate,24) from dual;

№14:判断某一日子所在年分是否为润年
select decode(to_char(last_day(trunc(sysdate,'y')+31),'dd'),'29','闰年','平年') from dual;

№15:判断两年后是否为润年
select decode(to_char(last_day(trunc(add_months(sysdate,24),'y')+31),'dd'),'29','闰年','平年') from dual;

№16:得到日期的季度

select ceil(to_number(to_char(sysdate,'mm'))/3) from dual;

select to_char(sysdate, 'Q') from dual;

http://tb.blog.csdn.net/TrackBack.aspxPostId=1475579

时间: 2024-09-17 04:18:09

Oracle中日期方面的SQL实例的相关文章

格式-关于oracle中日期比较出现问题

问题描述 关于oracle中日期比较出现问题 select a.* 2 if_dj_check from v_sj_corp a where exists (select 1 from t_m_corp_corp_stock m t_corp_stock s1 where a.id = m.id and a.org = m.org and a.seq_id = m.seq_id and s1.id = m.sub_id and s1.org = m.sub_org and s1.seq_id =

如何取得oracle中日期的时分秒啊?

问题描述 如何取得oracle中日期的时分秒啊?SimpleDateFormat f = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");System.out.println(f.format(obj[3]));进行了日期格式转换,打印出来的是 2012-03-19 00:00:00 但是数据库里面有正常的时分秒,怎么处理啊? 问题补充:yeqing4562011 写道 解决方案 LZ可测试下以下代码public static void main

dedecms-织梦中标签里面的sql语句中arc是什么表?

问题描述 织梦中标签里面的sql语句中arc是什么表? 这是arclist标签中的一段. 这个arc是什么表,估计是dede_archives ,但是怎么能这样写的呢? $query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart, tp.moresite,tp.siteurl,tp.sitepath $addfields

oracle中字段名与sql关键词重复的处理方法

ORACLE中,如果表中的字段名,正好跟sql中关键词重名,写sql语句时: 1.要将该字段名大写 2.字段名前后要加双引号(注:必须是双引号,单引号将无效) 比如:SELECT * FROM MYTABLE ORDER BY "ORDER"

oracle中得到一条SQL语句的执行时间的两种方式_oracle

oracle中如果需要得到一条SQL语句的执行时间可以用如下2种方式 复制代码 代码如下: SQL> set timing on; SQL> select count(*) from wea; COUNT(*) ---------- 39490 已用时间: 00: 00: 00.06 SQL> select sql_text, elapsed_time from v$sql 2 where sql_text like 'select count(*) from wea'; 未选定行 已用

Oracle中CASE WHEN的用法实例

  实例演示: (1)查询表users中的数据. select u.id,u.realname,U.SEX from users u; 查询结果如下 ID    REALNAME SEX 1  10082 松XX 2  10084 林XX     1 3  10087 西XX 4  10100 胡XX 5  10102 龙XX     1 ...... (2)上表结果中的"sex"是用代码表示的,希望将代码用中文表示.可在语句中使用CASE语句. select u.id,u.realn

oracle 中,下面哪个SQL效率比较高?

问题描述 要对比两张表TA和TB: select * from TA a where not exists (select v_key from TB b where a.v_key = b.v_key); select * from TA, (select v_key from TB) c where TA.v_key = c.v_key(+) and c.v_key is null;如果表TA和TB都有大量数据的话,哪个效率会比较高一点? 问题补充:话说能不能顺便稍微解释一下为什么较快或者较

Oracle 的存储过程里面的SQL 语句(|| “!”)看不懂,望大家给个答案

问题描述 create or replace package body pck_imp_puryewu is procedure searchList( i_FLDPURCONTRACTNO in varchar2, i_JK_DDH in varchar2, i_FLDCREATEDATE in varchar2, i_VERIFY in varchar2, i_userId in varchar2, o_retCode out varchar2, o_tableHead out varcha

ORACLE中数据递归查询遍历sql语句

查询遍历,需要在将数据在基表中按照层次结构进行存储.比如一个组织机构就是这样的典型例子: 实现语句: select column from table_name start with column=value connect by prior 父主键=子外键 例1:在oracle的emp 表中,每一条记录都有一个唯一标识当前雇员的empno和标识这个雇员的经理的mgr列.如果mgr 为空,则该雇员是该机构的最顶级.现在要列出每个雇员的层次结构(从顶到底): select lpad(' ',4*(