sql查询本月
‘壹’ 求DB2数据库查询本月内所有数据,哪位大神知道这样的sql应该怎么写
SELECT * FROM T WHERE YEAR(DATE) = YEAR(CURREN T DATE) AND MONTH(DATE) = MONTH(CURRENT DATE);
如伍绝果数据量太拦乎大,这个可能有效率问题建议用下面腔衡姿的
SELECT * FROM T WHERE DATE BETWEEN CURRENT DATE - (DAY(CURRENT DATE -1) AND CURRENT DATE;
‘贰’ SQL查询本月内到期的记录
SELECT * FROM 表 WHERE 日期 BETWEEN GETDATE() AND DATEADD(DAY,30,GETDATE())
‘叁’ sql 查询一个月里的数据
SQL中查询一个月里的数据,肢做举例及解决方法如下:
1、假如要查询表t1字段mydate为2015-10-1至2015-10-31之间的所有数据。
2、可以使用以拍弊下查询语句:
SELECT*FROMt1WHEREmydateBETWEEN'2015-10-01'and'2015-10-31'袭饥族;
‘肆’ 【求】如何在SQL Server中查询本周 本月 本期的记录
分类: 电脑/网络 >> 程序设计 >> 其他编程肆轮举语言
问题描述:
求如何在SQL Server中查询本周 本月 本期的记录,help!
解析:
这样,比如:
表名为:tableName
时间字段名裂碧为:theDate
查询本月的记录
select * from tableName where DATEPART(mm, theDate) = DATEPART(mm, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())
查询本周的记录
select * from tableName where DATEPART(wk, theDate) = DATEPART(wk, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())
查询本季的记录桐携
select * from tableName where DATEPART(qq, theDate) = DATEPART(qq, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())
其中:GETDATE()是获得系统时间的函数。
‘伍’ 【求各位大神!】SQL查询出本月所有日期
--MSSQL
--查询出本年所有日期:
SELECTCONVERT(VARCHAR(10),DATEADD(DD,number,DATENAME(YY,GETDATE())+'0101'),23)
FROMmaster..spt_values
WHEREtype='p'ANDnumber<=DATEDIFF(DD,DATENAME(YY,GETDATE())+'0101',DATENAME(YY,GETDATE())+'1231')
--查询出本月所有日期:
SELECTCONVERT(VARCHAR(10),DATEADD(DD,number,DATENAME(YY,GETDATE())+DATENAME(MM,GETDATE())+'01'),23)
FROMmaster..spt_values
WHEREtype='p'ANDnumber<DAY(DATEADD(MM,1,GETDATE())-DAY(GETDATE()))
‘陆’ 在sql server 2008中如何查询本日、本周和本月数据
--本日
select*fromtablewherecolbetweencast((convert(varchar(10),getdate(),120)asdatetime)andcast((convert(varchar(10),getdate(),120)+'23:59:59.997'asdatetime)
或
SELECT*FROMtableWHEREdatediff(day,col,getdate())=0
--本周
SELECT*FROMtableWHEREdatediff(week,col,getdate())=0
--本月
select*fromtablewherecolbetweencast((convert(varchar(7),getdate(),120)+'-1'asdatetime)andcast((convert(varchar(7),dateadd(m,1,,getdate()),120)+'-1'asdatetime)
‘柒’ 能否用一句SQL同时查询本日和本月金额总值
本月的直接加,本日的用case when来加,脚本实燃谈例如下,以oracle为例:
selectsum(金额)本月的金额总数,
sum(casewhen日期字段>=trunc(sysdate)then金额else0end)今日的金额总数
from表名
where日期字段>=trunc(sysdate,'mm')
在sqlserver中case when 语法闹段者与上面一致:
selectsum(金额)本月的金额总数,
sum(casewhen日期字段>=cast(convert(varchar,getdate(),112)assmalldatetime)then金额else0end)今日液薯的金额总数
from表名
where日期字段>=cast(convert(varchar(6),getdate(),112)+'01'assmalldatetime)
‘捌’ mysql查询本月数据sql怎么写
首先要考虑给数据库减压,意思就是让数据库做最简单的事情。你可以把条件在php里边组装好,然后让mysql只单一的执行查询就好了,php的时间代码给你贴一下吧
';
//php获取今判颂段日开始时间戳和结束时间戳?
$beginToday=mktime(0,0,0,date('m'),date('d'),date('Y'));
$endToday=mktime(0,0,0,date('掘誉m'),date('d')+1,date('Y'))-1;
echo?"今日开始时间戳和结束时间戳",'开始:',$beginToday,'结束:',$endToday,'
';
echo?"今日开始时间:",date("Y-m-d?H:i:s",$beginToday),'
';
echo?"今日结束时间:",date("樱指Y-m-d?H:i:s",$endToday),'
';
echo?'';
//php获取昨日起始时间戳和结束时间戳
$beginYesterday=mktime(0,0,0,date('m'),date('d')-1,date('Y'));
$endYesterday=mktime(0,0,0,date('m'),date('d'),date('Y'))-1;?
echo?"昨日开始时间戳和结束时间戳",'开始:',$beginYesterday,'结束:',$endYesterday,'
';
echo?"昨日开始时间:",date("Y-m-d?H:i:s",$beginYesterday),'
';
echo?"昨日结束时间:",date("Y-m-d?H:i:s",$endYesterday),'
';
echo?'';
//php获取上周起始时间戳和结束时间戳
$beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
$endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));
echo?"上周开始时间戳和结束时间戳",'开始:',$beginLastweek,'结束:',$endLastweek,'
';
echo?"上周开始时间:",date("Y-m-d?H:i:s",$beginLastweek),'
';
echo?"上周结束时间:",date("Y-m-d?H:i:s",$endLastweek),'
';
echo?'';
//php获取本月起始时间戳和结束时间戳
$beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
$endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));
echo?"本月开始时间戳和结束时间戳",'开始:',$beginThismonth,'结束:',$endThismonth,'
';
echo?"本月开始时间:",date("Y-m-d?H:i:s",$beginThismonth),'
';
echo?"本月结束时间:",date("Y-m-d?H:i:s",$endThismonth),'
';
?>
‘玖’ sql题 如何统计查询一个月中每天的记录
1、查询当天的所有数据
结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。
它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。
‘拾’ 获取本月、本季、本年第一天和最后一天等等sql(sql server)
转自: http://blog.itpub.net/183473/viewspace-723253
--DATEDIFF ( datepart , startdate , enddate )
--DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数
--DATEADD ( datepart , number, date )
--DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期
--计算一个月第一天
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
--本周的星期一,这里我是用周(wk)的时间间隔来计算哪一天是本周的星期一。
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)
--一年的第一天,现在用年(yy)的时间间隔来显示这一年的第一天。
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
--季度的第一天,假如你要计算这个季度的第一天,这个例子告诉你该如何做。
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
--上个月的最后一天,这是一个计算上个月最后一天的例子。它通过从一个月的最后一天这个例子上减去3毫秒来获得。有一点要记住,在Sql Server中时间是精确到3毫秒。这就是为什么我需要减去3毫秒来获得我要的日期和时间。
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
--去年的最后一天,连接上面的例子,为了要得到去年的最后一天,你需要在今年的第一天上减去3毫秒。
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
--本月的最后一天,现在,为了获得本月的最后一天,我需要稍微修改一下获得上个月的最后一天的语句。宽棚修改需要给用DATEDIFF比较当前日期和“1900-01-01”返回的时间间隔上加1。通过加1个月,我计算出下个月的第一天,然后减去3毫秒,这样就计算出了这个月的最后一天。这是计算本月最后一天的SQL脚本。
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
--本年的最后一天,你现在应该掌握这个的做法,这是计算本年最后一天脚本
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))
--本月的第一个星期一,好了,现在是最后一个例子。这里我要计算这个月的第一个星期一。这是计算的脚本。
SELECT DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)
--a. 本月的第一天
select dateadd(mm, datediff(mm,0,getdate()), 0) AS 本月的第一天
--b. 本月的最后一天
select dateadd(ms,-3,dateadd(mm, datediff(mm,0,getdate())+1, 0)) AS 本月的最后一天
--c. 上个月的最后前慎一天
select dateadd(ms,-3,dateadd(mm, datediff(mm,0,getdate()), 0)) AS 上个月的最后一天
--d. 本周的星慧巧敬期一
select dateadd(wk, datediff(wk,0,getdate()), 0) AS 本周的星期一
--e. 本季度的第一天
select dateadd(qq, datediff(qq,0,getdate()), 0) AS 本季度的第一天
--f. 本季度的最后一天
select DATEADD(ms,-3,dateadd(qq, datediff(qq,0,getdate())+1, 0)) AS 本季度的最后一天
--g. 本月的第一个星期一
select dateadd(wk, datediff(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0) AS 本月的第一个星期一
--h. 本年的第一天
select dateadd(yy, datediff(yy,0,getdate()), 0) AS 本年的第一天
--i. 本年的最后一天
select dateadd(ms,-3,dateadd(yy, datediff(yy,0,getdate())+1, 0)) AS 本年的最后一天
--f. 去年的最后一天
select dateadd(ms,-3,dateadd(yy, datediff(yy,0,getdate()), 0)) AS 去年的最后一天