Ⅰ sql中查出两个日期之间的数据
查出两个日期之间的数据的sql示例:
select * from table_name where date>'2010-1-1' and data<'2010-5-1';
其中table_name是表名,date是日期字段,and符号表示且,连接两个日期表示既满足大于2010-1-1又满足小于2010-5-1,在两个之间的数据。
(1)sql日期返回两日期之间扩展阅读
常用查询sql语句介绍:
1、查看表结构
SQL>DESC emp;
2、 查询所有列
SQL>SELECT * FROM emp;
3、查询指定列
SQL>SELECT empmo, ename, mgr FROM emp;
SQL>SELECT DISTINCT mgr FROM emp; 只显示结果不同的项
4、 查询指定行
SQL>SELECT * FROM emp WHERE job='CLERK';
5、使用算术表达式
SQL>SELECT ename, sal*13+nvl(comm,0) FROM emp;
Ⅱ sql两个日期之间怎么用函数表示
DATEDIFF
返回跨两个指定日期的日期和时间边界数。
语法
DATEDIFF ( datepart ,startdate ,enddate )
参数
datepart
是规定了应在日期的哪一部分计算差额的参数。下表列出了 Microsoft® SQL Server™ 识别的日期部分和缩写。
日期部分缩写
year yy, yyyy
quarter qq, q
Month mm, m
dayofyear dy, y
Day dd, d
Week wk, ww
Hour hh
minute mi, n
second ss, s
millisecond ms
startdate
是计算的开始日期。startdate 是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。
因为 smalldatetime 只精确到分钟,所以当用 smalldatetime 值时,秒和毫秒总是 0。
如果您只指定年份的最后两位数字,则小于或等于"两位数年份截止期"配置选项的值的最后两位数字的数字所在世纪与截止年所在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止年所在世纪的前一个世纪。例如,如果 two digit year cutoff 为 2049(默认),则 49 被解释为 2049,2050 被解释为 1950。为避免模糊,请使用四位数的年份。
有关时间值指定的更多信息,请参见时间格式。有关日期指定的更多信息,请参见 datetime 和 smalldatetime。
enddate
是计算的终止日期。enddate 是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。
返回类型
integer
注释
startdate 是从 enddate 减去。如果 startdate 比 enddate 晚,返回负值。
当结果超出整数值范围,DATEDIFF 产生错误。对于毫秒,最大数是 24 天 20 小时 31 分钟零 23.647 秒。对于秒,最大数是 68 年。
计算跨分钟、秒和毫秒这些边界的方法,使得 DATEDIFF 给出的结果在全部数据类型中是一致的。结果是带正负号的整数值,其等于跨第一个和第二个日期间的 datepart 边界数。例如,在 1 月 4 日(星期日)和 1 月 11 日(星期日)之间的星期数是 1。
示例
此示例确定在 pubs 数据库中标题发布日期和当前日期间的天数。
USE pubs
GO
SELECT DATEDIFF(day, pubdate, getdate()) AS no_of_days
FROM titles
GO
Ⅲ 利用SQL语句如何获得两个日期之间相差的天数
用sysdate假设结束日期字段是end_date
添加这个判断条件:
where to_char("end_date",'YYYY') = to_char(sysdate,'YYYY') 判断年相同
and to_char("end_date",'MM') = to_char(sysdate,'MM') 判断月相同
and to_char("end_date",'dd') - to_char(sysdate,'dd') = 15 判断日相同
或者:
where to_char("end_date",'YYYY-MM-DD') - to_char(sysdate,'YYYY-MM-DD')=15
(3)sql日期返回两日期之间扩展阅读:
注意事项
DATEDIFF返回跨两个指定日期的日期和时间边界数。
语法:DATEDIFF ( datepart , startdate , enddate )
参数:datepart
是规定了应在日期的哪一部分计算差额的参数。下表列出了 Microsoft® SQL Server™ 识别的日期部分和缩写。
startdate是返回datetime或smalldatetime值或日期格式字符串的表达式。 因为smalldatetime只精确到分钟,所以当用smalldatetime值时,秒和毫秒总是 0。
如果只指定年份的最后两位数字,则小于或等于"两位数年份截止期"配置选项的值的最后两位数字的数字所在世纪与截止年所在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止年所在世纪的前一个世纪。例如,如果 two digit year cutoff 为 2049(默认),则 49 被解释为 2049,2050 被解释为 1950。为避免模糊,请使用四位数的年份。
有关时间值指定的更多信息,请参见时间格式。有关日期指定的更多信息,请参见 datetime 和 smalldatetime。
enddate是计算的终止日期。enddate 是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。
返回类型:integer
注释:startdate 是从 enddate 减去。如果 startdate 比 enddate 晚,返回负值。当结果超出整数值范围,DATEDIFF 产生错误。对于毫秒,最大数是 24 天 20 小时 31 分钟零 23.647 秒。对于秒,最大数是 68 年。
Ⅳ 在Sql语句中怎样计算出两个日期的差值
sql语句中计算两个日期的差值用datediff函数。
工具:sqlserver 2008 R2
步骤:
1、计算2009-06-23与2009-06-17之间的天数。语句如下:
selectdatediff(d,'2009-06-17','2009-06-23')
2、查询结果:
Ⅳ 用SQL怎么取两个日期之间的日期
select 日期 from 表名 where 日期 between '2009-06-05' and '2009-06-08'
Ⅵ 如何用SQL返回两个日期之间的所有连续日期
在层次查询中,Oracle引入了一个伪列level,用来表示当前行(节点)对应的level,
它从1开始计数,每多一层level的值就加1。
我们可以据此实现对两个日期/整数之间所有日期/整数的遍历。
----------------------------------------------------------
SQL> create table test (begin_date date,end_date date);
Table created
SQL> insert into test values(trunc(sysdate),trunc(sysdate+5));
1 row inserted
SQL> select * from test;
BEGIN_DATE END_DATE
----------- -----------
2010-4-6 2010-4-11
SQL> select begin_date,end_date,begin_date+level -1 as today
2 from test
3 connect by begin_date + level -1 <= end_date;
BEGIN_DATE END_DATE TODAY
----------- ----------- -----------
2010-4-6 2010-4-11 2010-4-6
2010-4-6 2010-4-11 2010-4-7
2010-4-6 2010-4-11 2010-4-8
2010-4-6 2010-4-11 2010-4-9
2010-4-6 2010-4-11 2010-4-10
2010-4-6 2010-4-11 2010-4-11
6 rows selected
------------------------------------------------------------------插入两条记录,看该查询语句是否可行
SQL> insert into test values(trunc(sysdate+4),trunc(sysdate+7));
1 row inserted
SQL> select * from test;
BEGIN_DATE END_DATE
----------- -----------
2010-4-6 2010-4-11
2010-4-10 2010-4-13
SQL> select distinct begin_date+level-1 as today
2 from test
3 connect by begin_date+level-1 <= end_date;
TODAY
-----------
2010-4-7
2010-4-13
2010-4-8
2010-4-11
2010-4-9
2010-4-6
2010-4-10
2010-4-12
8 rows selected
--------------------------------------- 根据最大和最小值得查询
SQL> delete from test where begin_date = to_date('2010-4-10','yyyy-mm-dd');
1 row deleted
SQL> select * from test;
BEGIN_DATE END_DATE
----------- -----------
2010-4-6 2010-4-11
SQL> SELECT one_date
2 FROM (SELECT start_date + level - 1 one_date
3 FROM (SELECT min(begin_date) start_date, max(end_date) end_date
4 FROM test) test
5 connect BY start_date + level - 1 <= end_date ) all_date,
6 test
7 WHERE one_date BETWEEN begin_date AND end_date;
ONE_DATE
-----------
2010-4-6
2010-4-7
2010-4-8
2010-4-9
2010-4-10
2010-4-11
6 rows selected
Ⅶ SQL语句如何判断一个日期在两个日期之间
1、创建测试表,
create table test_date_bet(id varchar2(20),v_date date);
Ⅷ sqlserver中返回两个日期间相差几年零几月
select datediff(month,'2017-1-5','2018-05-25')/12 ,datediff(month,'2017-1-5','2018-05-25')%12
执行结果:1年4个月
注释:
datediff(month,'2017-1-5','2018-05-25')取出两个日期相差的总月数;
datediff(month,'2017-1-5','2018-05-25')/12 取出两个日期相差的总年数。
datediff(month,'2017-1-5','2018-05-25')%12 取出总年数后,剩余月数。
Ⅸ 第四十三章 SQL函数 DATEDIFF
日期/时间函数,返回两个日期之间指定日期部分的整数差。
DATEDIFF 函数返回两个指定日期之间指定日期部分差的整数。日期范围从开始日期开始,到结束日期结束。(如果 enddate 早于 startdate , DATEDIFF 将返回一个负整数值。)
DATEDIFF 返回 startdate 和 enddate 之间指定单位的总数。例如,两个日期时间值之间的分钟数计算日期部分和时间部分,并为每一天的差异增加 1440 分钟。 DATEDIFF 返回开始日期和结束日期之间跨越的指定日期部分边界的计数。例如,指定连续年份的任意两个日期(例如 2018-09-23 和 2019-01-01 )返回的年份 DATEDIFF 为1,而不管这两个日期之间的实际持续时间是大于还是小于 365 天。同样, 12:23:59 和 12:24:05 之间的分钟数是1,尽管实际上只有 6 秒将两个值分开。
请注意, DATEDIFF 是为Sybase和Microsoft SQL Server兼容性而提供的。使用 TIMESTAMPDIFF ODBC 标量函数可以执行类似的时间/日期比较操作。
也可以使用 DATEDIFF() 方法调用从 ObjectScript 调用此函数:
为 DATEDIFF() 方法指定无效的 datepart 、 startdate 或 enddate 会生成 < ZDDIF > 错误。
日期部分参数可以是下列日期/时间组件之一,可以是全名(日期部分列)或其缩写(缩写列)。这些 datepart 组件名称和缩写不区分大小写。
weekday 和 dayofyear datepart 值在功能上与 day datepart 值相同。
DATEDIFF 和 TIMESTAMPDIFF 不处理季度(间隔 3 个月)。
如果指定包含分数秒的开始日期和结束日期, DATEDIFF 将以分数秒的整数形式返回差值,如下例所示:
datepart 可以指定为带引号的字符串或不带引号的字符串。这些语法变体执行略有不同的操作:
startdate 和 enddate 参数可以采用不同的数据类型格式。
startdate 和 enddate 参数可以采用以下任何格式:
%String (或 compatible )值可以是以下任何一种格式,可以包含或省略小数秒:
Sybase/SQL-Server-date是以下五种格式之一:
在第一种语法格式中,分隔符可以是斜杠( / )、连字符( - )或句点( . )。
Sybase/SQL-Server-time表示以下三种格式之一:
如果年份以两位数字表示,或者日期被完全省略, IRIS会检查滑动窗口来解释日期。
系统范围内滑动窗口的默认值是 1900 ;
因此,在默认情况下,两位数的年份被认为是在20世纪。
如下示例所示:
DATEDIFF 返回以毫秒(3位整数)、微秒(6位整数)或纳秒(9位整数)表示的小数秒,而不管 startdate 和 enddate 中的小数位数精度是多少。
如下示例所示:
一些NLS区域设置将分数分隔符指定为逗号(欧洲的用法),而不是句号。
如果当前区域设置是这些区域设置之一, DATEDIFF 接受句号或逗号作为本地日期格式的秒分隔符。
对于 $HOROLOG 格式的日期或 ODBC 格式的日期,不能使用逗号作为小数秒分隔符。
尝试这样做会生成一个 SQLCODE -8 。
无论当前的NLS语言环境是什么,这两种格式都需要一段时间。
DATEDIFF 返回以秒和毫秒为单位的时间差,即使当前进程的 TimeFormat 被设置为不返回秒。
如下示例所示:
DATEDIFF 对输入值执行以下检查:
下面的例子返回 353 ,因为两个时间戳之间有 353 天(D):
在下面的示例中,每个 DATEDIFF 返回 1 ,因为日期的年份部分相差1。
日期之间的实际持续时间不被考虑:
注意,上面的例子使用了日期部分的缩写。
但是,你可以指定全名,如下例所示:
下面的嵌入式SQL示例使用主机变量执行与前面示例相同的 DATEDIFF 操作:
下面的例子使用 WHERE 子句中的 DATEDIFF 来选择上周入院的患者:
下面的例子使用了一个子查询来返回那些个人的出生日期距当前日期不超过 1500 天的记录: