oracle日期时间范围查询,Oracle的日期时间范围查询-Oracle

本文展示了在Oracle数据库中如何进行日期时间范围查询的多种方式,包括使用比较运算符(=, >, <, >=, <=)以及BETWEEN子句,涉及字符串类型和日期时间类型的字段。示例代码涵盖了不同格式的日期时间处理,如'yyyy-MM-dd'和'yyyy-MM-ddHH24:MI:SS'。这些查询技巧对于数据库操作和数据筛选至关重要。
摘要由CSDN通过智能技术生成

Oracle日期时间范围查询

Sql代码

/* 日期时间范围查询 */

———- 创建日期时间测试表———————————————————–    www.2cto.com

create table testdatetime(

ID integer not null primary KEY,

createdate  CHAR(10)  NULL,

startdate DATE NULL,

enddate DATE NULL,

buydate  CHAR(10)  NULL,

usedate  varchar2(20)  NULL

) ;

———————— 日期时间范围查询 ————————————

SELECT t.*,t.ROWID FROM testdatetime t ;

–字段为:字符串类型(char),长度为:10

SELECT * FROM testdatetime t WHERE 1=1 AND t.createdate = ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.createdate > ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.createdate < ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.createdate >= ‘2011-06-01’ AND

t.createdate <= ‘2011-07-05’;    www.2cto.com

SELECT * FROM testdatetime t WHERE 1=1 AND to_date(t.createdate,’yyyy-MM-dd’) between to_date(‘2011-06-01′,’yyyy-MM-dd’) and to_date(‘20110705′,’yyyymmdd’) ;

——————————————————————-

SELECT t.*,t.ROWID FROM testdatetime t ;

–字段为:字符串类型(char),长度为:20

SELECT * FROM testdatetime t WHERE 1=1 AND t.usedate = ‘2011-07-01 10:00:00’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.usedate > ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.usedate < ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND t.usedate >= ‘2011-06-01’ AND t.usedate <= ‘2011-07-05’;

SELECT * FROM testdatetime t WHERE 1=1 AND to_date(t.usedate,’yyyy-MM-dd HH24:MI:SS’)

between to_date(‘2011-07-01 12:00:00′,’yyyy-MM-dd HH24:MI:SS’) and to_date(‘20110702 12:00:00′,’yyyymmdd HH24:MI:SS’) ;

————————————————————————-

SELECT t.*,t.ROWID FROM testdatetime t ;

–字段为:日期时间类型(date)  www.2cto.com

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate = to_date(‘2011-07-01′,’yyyy-MM-dd’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate > to_date(‘2011-07-01′,’yyyy-MM-dd’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate < to_date(‘2011-07-01′,’yyyy-MM-dd’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate >= to_date(‘2011-07-01′,’yyyy-MM-dd’)

AND t.startdate <= to_date(‘2011-07-02′,’yyyy-MM-dd’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate between to_date(‘2011-07-01′,’yyyy-MM-dd’) AND to_date(‘2011-07-02′,’yyyy-MM-dd’);

———————-

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate = to_date(‘2011-07-01 12:00:00′,’yyyy-MM-dd HH24:MI:SS’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate > to_date(‘2011-07-01 12:00:00′,’yyyy-MM-dd HH24:MI:SS’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate < to_date(‘2011-07-01 12:00:00′,’yyyy-MM-dd HH24:MI:SS’);

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate >= to_date(‘2011-07-01 01:00:00′,’yyyy-MM-dd HH24:MI:SS’) AND t.startdate <= to_date(‘2011-07-01 23:00:00′,’yyyy-MM-dd HH24:MI:SS’);    www.2cto.com

SELECT * FROM testdatetime t WHERE 1=1 AND t.startdate between to_date(‘2011-07-01 01:00:00′,’yyyy-MM-dd HH24:MI:SS’) AND to_date(‘2011-07-01 23:00:00′,’yyyy-MM-dd HH24:MI:SS’);

———————–

SELECT * FROM testdatetime t WHERE 1=1 AND to_char(t.startdate,’yyyy-MM-dd’) = ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND to_char(t.startdate,’yyyy-MM-dd’) > ‘2011-07-01’;

SELECT * FROM testdatetime t WHERE 1=1 AND to_char(t.startdate,’yyyy-MM-dd’) < ‘2011-07-01’;    www.2cto.com

SELECT * FROM testdatetime t WHERE 1=1 AND to_char(t.startdate,’yyyy-MM-dd’) >= ‘2011-07-01′ AND to_char(t.startdate,’yyyy-MM-dd’) <= ‘2011-07-02’;

SELECT * FROM testdatetime t WHERE 1=1 AND to_char(t.startdate,’yyyy-MM-dd’) between ‘2011-07-01’ AND  ‘2011-07-02’;

作者 weishaoxiang

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值