`
bjtdeyx
  • 浏览: 170202 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

用sql查询当天,一周,一个月的数据(不支持Oracle、mysql)

阅读更多

一、首先了解DateDiff 函数的用法

语法

返回 Variant (Long) 的值,表示两个指定日期间的时间间隔数目。 
 DateDiff(interval, date1, date2[, firstdayofweek[, firstweekofyear]])  DateDiff 函数语法中有下列命名参数:  部分 描述  interval 必要。字符串表达式,表示用来计算date1 和 date2 的时间差的时间间隔  Date1□date2 必要;Variant (Date)。计算中要用到的两个日期。  Firstdayofweek 可选。指定一个星期的第一天的常数。如果未予指定,则以星期日为第一天。  firstweekofyear 可选。指定一年的第一周的常数。如果未予指定,则以包含 1 月 1 日的星期为第一周。


参数设置

interval 参数的设定值如下:  设置 描述  yyyy 年  q 季  m 月  y 一年的日数  d 日  w 一周的日数  ww 周  h 时  n 分钟  s 秒  firstdayofweek 参数的设定值如下:  常数 值 描述  vbUseSystem 0 使用 NLS API 设置。  vbSunday 1 星期日(缺省值)  vbMonday 2 星期一  vbTuesday 3 星期二  vbWednesday 4 星期三  vbThursday 5 星期四  vbFriday 6 星期五  vbSaturday 7 星期六  常数 值 描述  vbUseSystem 0 用 NLS API 设置。  vbFirstJan1 1 从包含 1 月 1 日的星期开始(缺省值)。  vbFirstFourDays 2 从第一个其大半个星期在新的一年的一周开始。  vbFirstFullWeek 3 从第一个无跨年度的星期开始。


函数说明

DateDiff 函数可用来决定两个日期之间所指定的时间间隔数目。例如,可以使用 DateDiff 来计算两个日期之间相隔几日,或计算从今天起到年底还有多少个星期。  为了计算 date1 与 date2 相差的日数,可以使用“一年的日数”(y) 或“日”(d)。当 interval 是“一周的日数”(w) 时,DateDiff 返回两日期间的周数。如果 date1 是星期一,DateDiff 计算到 date2 为止的星期一的个数。这个数包含 date2 但不包含 date1。不过,如果 interval 是“周”(ww),则 DateDiff 函数返回两日期间的“日历周”数。由计算 date1 与 date2 之间星期日的个数而得。如果 date2 刚好是星期日,则 date2 也会被加进 DateDiff 的计数结果中;但不论 date1 是否为星期日,都不将它算进去。  如果 date1 比 date2 来得晚,则 DateDiff 函数的返回值为负数。  firstdayofweek 参数会影响使用时间间隔符号 “W” 或 “WW” 计算的结果。  如果 date1 或 date2 是日期文字,则指定的年份成为该日期的固定部分。但是,如果 date1 或 date2 用双引号 (" ") 括起来,且年份略而不提,则在每次计算表达式 date1 或 date2 时,当前年份都会插入到代码之中。这样就可以书写适用于不同年份的程序代码。  在计算 12 月 31 日和来年的 1 月 1 日的年份差时,DateDiff 返回 1 表示相差一个年份,虽然实际上只相差一天而已。

适用数据库

此示例确定在 pubs 数据库中标题发布日期和当前日期间的天数。  USE pubsGOSELECT DATEDIFF(day, pubdate, getdate()) AS no_of_daysFROM titlesGO  DATEDIFF函数在Access和MSSQL中的使用区别  ACCESS中用法:DATEDIFF('day', pubdate, Now())  MSSQL中用法:DATEDIFF(day, pubdate, getdate())  Sybase中用法:DATEDIFF(dd, pubdate, getdate())


数据查询,不管在网站还是在系统,都很常见,下文是介绍最常见的以日期查询的语句
select * from ShopOrder where datediff(week,ordTime,getdate()-1)=0   //查询当天日期在一周年的数据

 

select * from ShopOrder where datediff(day,ordTime,getdate()-1)=0   //查询当天的所有数据

 

--查询当天: 
select * from info where DateDiff(dd,datetime,getdate())=0 

--查询24小时内的: 
select * from info where DateDiff(hh,datetime,getDate())<=24 

--info为表名,datetime为数据库中的字段值

--查询当天:
select * from info where DateDiff(dd,datetime,getdate())=0

--查询24小时内的:
select * from info where DateDiff(hh,datetime,getDate())<=24

--info为表名,datetime为数据库中的字段值

Sql代码
--查询当天记录另类的方法 
SELECT * 
FROM j_GradeShop 
WHERE (GAddTime BETWEEN CONVERT(datetime, LEFT(GETDATE(), 10) + ’ 00:00:00.000’) 
AND CONVERT(datetime, LEFT(GETDATE(), 10) + ’ 00:00:00.000’) + 1) 
ORDER BY GAddTime DESC

--查询当天记录另类的方法
SELECT *
FROM j_GradeShop
WHERE (GAddTime BETWEEN CONVERT(datetime, LEFT(GETDATE(), 10) + ’ 00:00:00.000’)
AND CONVERT(datetime, LEFT(GETDATE(), 10) + ’ 00:00:00.000’) + 1)
ORDER BY GAddTime DESC

DATEDIFF 函数:

语法:


DATEDIFF ( datepart , startdate , enddate )

备注:enddate 减去 startdate。如果 startdate 晚于 enddate,则返回负值。

如果结果超出整数值范围,则 DATEDIFF 将产生错误。对于毫秒,最大数是 24 天 20 小时 31 分钟零 23.647 秒。对于秒,最大数是 68 年。

跨分钟、秒和毫秒等边界计算的方法使得 DATEDIFF 指定的结果在所有数据类型中均一致。结果是带正负号的整数值,它等于跨第一个和第二个日期间的 datepart 边界数。例如,在 1 月 4 日(星期日)和 1 月 11 日(星期日)之间的星期数是 1。


可以再MSSQL中测试:

Sql代码
--两个时间差刚好是24 
--打印的方式 
print dateDiff(hh,’2009-1-1 0:0:0’,’2009-1-2 0:0:0’) 

--查询的方式 
print dateDiff(hh,’2009-1-1 0:0:0’,’2009-1-2 0:0:0’)

--两个时间差刚好是24
--打印的方式
print dateDiff(hh,’2009-1-1 0:0:0’,’2009-1-2 0:0:0’)

--查询的方式
print dateDiff(hh,’2009-1-1 0:0:0’,’2009-1-2 0:0:0’)

Sql代码
--本月记录 
SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0 

--本周记录 
SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0 

--包括本年这些查询方式是一样的

--本月记录
SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0

--本周记录
SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0

sql server中的时间函数


1. 当前系统日期、时间
select getdate()


2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,’2004-10-15’) --返回:2004-10-17 00:00:00.000


3. datediff 返回跨两个指定日期的日期和时间边界数。
select datediff(day,’2004-09-01’,’2004-09-18’) --返回:17


4. datepart 返回代表指定日期的指定日期部分的整数。
SELECT DATEPART(month, ’2004-10-15’) --返回 10


5. datename 返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, ’2004-10-15’) --返回:星期五


6. day(), month(),year() --可以与datepart对照一下

select 当前日期=convert(varchar(10),getdate(),120)
,当前时间=convert(varchar(8),getdate(),114)

select datename(dw,’2004-10-15’)

select 本年第多少周=datename(week,’2004-10-15’)
,今天是周几=datename(weekday,’2004-10-15’)


函数 参数/功能
GetDate( ) 返回系统目前的日期与时间
DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1
DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期
DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值
DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称

参数 interval的设定值如下:


值 缩 写(Sql Server) Access 和 ASP 说明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq q 季 1 ~ 4
Month Mm m 月1 ~ 12
Day of year Dy y 一年的日数,一年中的第几日 1-366
Day Dd d 日,1-31
Weekday Dw w 一周的日数,一周中的第几日 1-7
Week Wk ww 周,一年中的第几周 0 ~ 51
Hour Hh h 时0 ~ 23
Minute Mi n 分钟0 ~ 59
Second Ss s 秒 0 ~ 59
Millisecond Ms - 毫秒 0 ~ 999

 

access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似


举例:
1.GetDate() 用于sql server :select GetDate()

2.DateDiff(’s’,’2005-07-20’,’2005-7-25 22:56:32’)返回值为 514592 秒
DateDiff(’d’,’2005-07-20’,’2005-7-25 22:56:32’)返回值为 5 天

3.DatePart(’w’,’2005-7-25 22:56:32’)返回值为 2 即星期一(周日为1,周六为7)
DatePart(’d’,’2005-7-25 22:56:32’)返回值为 25即25号
DatePart(’y’,’2005-7-25 22:56:32’)返回值为 206即这一年中第206天
DatePart(’yyyy’,’2005-7-25 22:56:32’)返回值为 2005即2005年

分享到:
评论

相关推荐

    Oracle Sql语句转换成Mysql Sql语句

    4. **游标**:Oracle SQL支持游标,MySQL则不直接支持,需要使用存储过程或临时表来实现类似功能。 5. **函数和操作符**:两者内置的函数和操作符有所不同,例如Oracle的NVL对应MySQL的IFNULL,Oracle的TO_DATE对应...

    Oracle数据库sql转换mysql数据库工具

    2. **数据迁移**:除了转换SQL,工具可能还支持数据的迁移,将Oracle数据库中的表数据导入到MySQL数据库中。 3. **对象转换**:包括表、索引、视图、存储过程、函数等数据库对象的转换。 4. **权限与用户管理**:...

    oracle到sqlserver 跨库查询

    Oracle 到 SQL Server 跨库查询是指通过网关工具将数据从 SQL Server 数据库中抽取到 Oracle 数据库中。这个过程需要安装和配置网关软件,并进行相应的设置和配置。 一、网关软件安装 网关软件的安装是跨库查询的...

    支持MYSQL和ORACLE数据库表

    Oracle提供了强大的ACID(原子性、一致性、隔离性、持久性)事务处理能力,并支持复杂的SQL查询和存储过程。Oracle数据库的特色包括RAC(Real Application Clusters)集群技术,允许在多台服务器上共享同一数据库,...

    Mysql转Oracle软件 DBMover for Mysql to Oracle

    使用DBMover可以灵活定义Mysql和Oracle之间表和字段的对照关系,也可以在DBMover创建一个查询,把查询结果当作源表转入到Oracle中。 Dbmover for Mysql to Oracle 可以定时,定周期自动运行。 支持 Oracle 8i 以后...

    oracle,sqlserver及mysql对比

    增加一个月,可以使用 ADD_MONTHS 函数在 Oracle 中,而 MySQL 使用 DATE_ADD 函数。截取字符串方面,Oracle 使用 SUBSTR 函数,而 MySQL 使用 SUBSTRING 函数。在 MySQL 中,从子句后的表如果是子查询形式,那么...

    sqlserver,mysql,oracle三种数据库的分页查询

    SQL Server使用TOP和OFFSET,MySQL依赖LIMIT和可能的子查询,而Oracle则利用ROWNUM。在实际应用中,需要根据数据库类型和数据量选择最适合的分页策略,同时注意优化查询以提升性能。在大数据场景下,考虑使用索引和...

    基于springboot的mysql,sqlserver,oracle数据源切换

    本项目着重探讨如何在SpringBoot中实现对MySQL、SQLServer、Oracle这三种主流数据库的数据源切换。 首先,我们来看包结构。一个标准的SpringBoot项目通常包含以下几个主要部分:`src/main/java`下的`...

    Oracle,SQl,MySql实现分页查询

    本文将基于提供的文件信息,深入探讨三种不同的分页查询方法及其在Oracle、SQL Server(这里用SQL代替)、MySQL中的实现方式,并对它们的性能进行对比分析。 #### 分页方案一:利用Not In和SELECT TOP分页 **基本...

    SpringBoot定时任务实现Oracle和mysql数据同步

    3. **查询数据**:在Oracle数据库中使用`Statement`或`PreparedStatement`执行SQL查询,获取需要同步的数据。 4. **数据转换**:根据业务需求,可能需要对查询结果进行处理,比如数据类型转换、格式化等。 5. **...

    Oracle SQLDeveloper Migration Workbench(MySQL to Oracle)

    ### Oracle SQL Developer Migration Workbench (MySQL to Oracle) #### 概述 随着企业信息化建设的不断深入,数据库迁移已经成为一种常见的需求。特别是在不同数据库系统之间的数据迁移过程中,如何保证数据的...

    把mysql数据库中的数据导入到oracle数据库中

    - 当前MySQL数据库的备份文件为`.sql`文件,每个表一个文件,需要将这些文件的数据导入到Oracle数据库中。 #### 二、MySQL数据恢复 为了确保数据的完整性和准确性,首先需要将MySQL的备份文件恢复到一个测试数据库...

    多数据库连接(支持MySql,Sqlserver,Oracle)

    这篇主要介绍的是一个C#编写的多数据库连接库,它支持MySQL、SQL Server和Oracle这三种常见的关系型数据库系统。这个库提供了一套统一的API,使得开发人员可以方便地进行跨数据库的操作,而无需为每个特定的数据库...

    递归查询菜单树,支持mysql,oracle

    在IT行业中,数据库管理和数据操作是...总的来说,递归查询菜单树是数据库操作的一个常见应用场景,它涉及到数据库设计、SQL查询技巧以及前后端的数据交换。理解并掌握这些知识点对于开发高效、可维护的系统至关重要。

    DBHelper数据库操作类(支持OleDb、MySQL、Oracle、SQL、SQLite).zip

    数据库操作类(支持OleDb、MySQL、Oracle、SQL、SQLite、) 操作: 获取连接字符串 得到web.config里配置项的数据库连接字符串。 数据库连接字符串(web.config来配置),可以动态更改connectionString支持多数据库. ...

    mysql7 oracle sql查询分析

    8. 大数据处理:Oracle 支持大型数据库和大数据解决方案,如Oracle NoSQL数据库和Oracle Big Data SQL,可以跨Hadoop和其他大数据平台执行SQL查询。MySQL 7在大数据处理方面可能不如Oracle强大,但可以通过连接到...

    sqlserver自动生成sql语句工具sqlserver转oracle

    市场上存在许多这样的工具,如SSMA(SQL Server Migration Assistant) for Oracle,这是一个官方提供的迁移工具,能自动分析SQL Server的架构,并生成适合Oracle的DDL(Data Definition Language)和DML(Data ...

    支持 oracle mysql sql server db2等数据库

    【标签】:“数据库客户端”表明这是一个专门用于与数据库交互的软件工具,它提供了图形化的用户界面(GUI)来执行SQL查询、管理数据库对象、监控数据库性能等操作。这样的客户端通常包含丰富的功能,如数据导入导出...

    使用LabVIEW操作ACCESS、MySQL、SQL server数据库实现按照时间段查询数据

    2. **调用SQL语句**:通过“Execute Query.vi”函数执行SQL查询。LabVIEW提供了三种执行SQL的方法,此处选择较为直观的一种。 3. **获取查询结果**:使用“Fetch Recordset Data.vi”函数获取查询到的数据。 4. **...

    通用SQL教程oracle,mysql,sqlserver

    本教程涵盖了SQL在三大主流数据库系统——Oracle、MySQL和SQL Server中的应用,旨在帮助学习者掌握通用的SQL知识,从而能够高效地进行数据查询、更新、插入和删除等操作。 在Oracle数据库中,SQL被广泛应用于数据的...

Global site tag (gtag.js) - Google Analytics