SQLServer查询今天-昨天-本周-本月的记录

合集下载

SQLServer各种日期计算方法

SQLServer各种日期计算方法

SQL Server各种日期计算方法通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天。

你们大部分人大概都知道怎样把日期进行分割(年、月、日等),然后仅仅用分割出来的年、月、日等放在几个函数中计算出自己所需要的日期!在这篇文章里,我将告诉你如何使用DATEADD和DATEDIFF函数来计算出在你的程序中可能你要用到的一些不同日期。

在使用本文中的例子之前,你必须注意以下的问题。

大部分可能不是所有例子在不同的机器上执行的结果可能不一样,这完全由哪一天是一个星期的第一天这个设置决定。

第一天(DATEFIRST)设定决定了你的系统使用哪一天作为一周的第一天。

所有以下的例子都是以星期天作为一周的第一天来建立,也就是第一天设置为7。

假如你的第一天设置不一样,你可能需要调整这些例子,使它和不同的第一天设置相符合。

你可以通过@@DATEFIRST函数来检查第一天设置。

为了理解这些例子,我们先复习一下DATEDIFF和DATEADD函数。

DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数。

DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期。

要了解更多的DATEDI FF和DATEADD函数以及时间间隔可以阅读微软联机帮助。

使用DATEDIFF和DATEADD函数来计算日期,和本来从当前日期转换到你需要的日期的考虑方法有点不同。

你必须从时间间隔这个方面来考虑。

比如,从当前日期到你要得到的日期之间有多少时间间隔,或者,从今天到某一天(比如1900-1-1)之间有多少时间间隔,等等。

理解怎样着眼于时间间隔有助于你轻松的理解我的不同的日期计算例子。

一个月的第一天第一个例子,我将告诉你如何从当前日期去这个月的最后一天。

请注意:这个例子以及这篇文章中的其他例子都将只使用DATEDIFF和DATEADD函数来计算我们想要的日期。

每一个例子都将通过计算但前的时间间隔,然后进行加减来得到想要计算的日期。

SQL语句统计每天、每月、每年的_数据

SQL语句统计每天、每月、每年的_数据

SQL语句统计每天、每月、每年的_数据1.//按天统计2.select count(dataid) as 每天操作数量, sum()3.from4.where5.group by trunc(createtime, 'DD'))6.//按自然周统计7.select to_char(date,'iw'),sum()8.from9.where10.group by to_char(date,'iw')11.//按自然月统计12.select to_char(date,'mm'),sum()13.from14.where15.group by to_char(date,'mm')16.//按季统计17.select to_char(date,'q'),sum()18.from19.where20.group by to_char(date,'q')21.//按年统计22.select to_char(date,'yyyy'),sum()23.from24.where25.group by to_char(date,'yyyy')SQL语句统计每天、每月、每年的数据1、每年select year(ordertime) 年,sum(Total) 销售合计from 订单表group by year(ordertime)2、每月select year(ordertime) 年,month(ordertime) 月,sum(Total) 销售合计from 订单表group by year(ordertime),month(ordertime3、每日select year(ordertime) 年,month(ordertime) 月,day(ordertime) 日,sum(Total) 销售合计from 订单表group by year(ordertime),month(ordertime),day(ordertime)另外每日也可以这样:select convert(char(8),ordertime,112) dt,sum(Total) 销售合计from 订单表group by convert(char(8),ordertime,112)sql题如何统计查询一个月中每天的记录怎么写啊?写出来啊!比如说要查2010年3月份每天的记录提问者:Java_Travler - 一级最佳答案select count(*),substr(t.date,1,10) from table t where t.date like '2010-03%' group by substr(t.date,1,10)这里date的格式是YYYY-mm-dd hh:mm:sssql 数据分月统计,表中只有每天的数据,现在要求求一年中每个月的统计数据(一条sql)SELECTMONTH ( 那个日期的字段),SUM( 需要统计的字段,比如销售额什么的)FROM表WHEREYEAR ( 那个日期的字段) = 2010 -- 这里假设你要查2010年的每月的统计。

sql 查询当天的记录,本月,本周的记录

sql 查询当天的记录,本月,本周的记录

sql 查询当天的记录,本月,本周的记录2010-09-07 00:27:14| 分类:默认分类| 标签:getdate datediff select interval返回字号:大中小订阅sql 查询当天的记录,本月,本周的记录sql 查询当天的记录,本月,本周的记录2006年12月27日星期三上午10:05SELECT * FROM 表WHERE CONVERT(Nvarchar, dateandtime, 111) = CONVERT(Nvarchar, GETDATE(), 111) ORDER BY dateandtime DESC本月记录SELECT * FROM 表WHEREdatediff(month,[dateadd],getdate())=0本周记录当天记录SELECT * FROM 表WHEREdatediff(day,[dateadd],getdate())=0sql server中的时间函数1. 当前系统日期、时间select getdate()2. dateadd 在向指定日期加上一段时间的基础上,返回新的datetime 值例如:向日期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003. datediff 返回跨两个指定日期的日期和时间边界数。

select datediff(day,'2004-09-01','2004-09-18') --返回:174. datepart 返回代表指定日期的指定日期部分的整数。

SELECT DATEPART(month, '2004-10-15') --返回105. 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-date1DateAdd (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 ~ 12Day of year Dy y 一年的日数,一年中的第几日1-366Day Dd d 日,1-31Weekday Dw w 一周的日数,一周中的第几日1-7Week Wk ww 周,一年中的第几周0 ~ 51Hour Hh h 时0 ~ 23Minute Mi n 分钟0 ~ 59Second Ss s 秒0 ~ 59Millisecond Ms - 毫秒0 ~ 999access 和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年SQL 查询当天,本月,本周的记录SELECT * FROM 表WHERE CONVERT(Nvarchar, dateandtime, 111) = CONVERT(Nvarchar, GETDATE (), 111) ORDER BY dateandtime DESC本月记录SELECT * FROM 表WHERE datediff(month,[dateadd],getdate())=0本周记录SELECT * FROM 表WHERE datediff(week,[dateadd],getdate())=0当天记录SELECT * FROM 表WHERE datediff(day,[dateadd],getdate())=0sql server中的时间函数1. 当前系统日期、时间select getdate()2. dateadd 在向指定日期加上一段时间的基础上,返回新的datetime 值例如:向日期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003. datediff 返回跨两个指定日期的日期和时间边界数。

sql查询本日本周本月本年的语句

sql查询本日本周本月本年的语句

备注:语法DATEPART(datepart,date)date参数是合法的日期表达式。

datepart参数可以是下列的值:datepart 缩写年yy, yyyy季度qq, q月mm, m年中的日dy, y日dd, d周wk, ww星期dw, w小时hh分钟mi, n秒ss, s毫秒ms微妙mcs纳秒nssql 查询本周本月问题---查询今日信息select * from 表名 where datediff(day,时间字段,getdate())=0 其中day可以换成其他时间函数如month等---求相差天数select datediff(day,'2004-01-01',getdate())--1.一个月第一天的SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)--2.本周的星期一SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)select dateadd(wk,datediff(wk,0,getdate()),6)--3.一年的第一天SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)--4.季度的第一天SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)--5.当天的半夜SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)--6.上个月的最后一天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))--7.去年的最后一天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))--8.本月的最后一天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))--9.本年的最后一天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0) )--10.本月的第一个星期一select DATEADD(wk,DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)--查询本周注册人数select count(*) from [user]where datediff(week,create_day-1,getdate())=0--上周注册人数select count(*) from [user]where datediff(week,create_day-1,getdate())=1--本月注册人数select count(*) from [user]where datediff(month,create_day,getdate())=0--上月注册人数select count(*) from [user]where datediff(month,create_day,getdate())=1--如果要效率,这样写查询--查询本周注册人数select count(*) from [user]where create_day>=dateadd(day,2-datepart(weekday,getdate()),convert (varchar,getdate(),112))and create_day<dateadd(day,9-datepart(weekday,getdate()),convert(va rchar,getdate(),112))--上周注册人数select count(*) from [user]where create_day>=dateadd(day,-5-datepart(weekday,getdate()),conver t(varchar,getdate(),112))and create_day<dateadd(day,2-datepart(weekday,getdate()),convert(va rchar,getdate(),112))--本月注册人数select count(*) from [user]where create_day>=dateadd(day,1-day(getdate()),convert(varchar,getd ate(),112))and create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert (varchar,getdate(),112)))--上月注册人数select count(*) from [user]where create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),con vert(varchar,getdate(),112)))and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate (),112))--本周select count(*) from Userwhere datediff(dd,create_day,getdate()) <= datepart(dw,getdate( ))--上周select count(*) from Userwhere datediff(dd,create_day,(getdate() - datepart(dw,getdate() ))) <= 7--本月select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate())--上月select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate()) - 1 --本周select count(*) from [User]where datediff(dd,create_day,getdate()) <= datepart(dw,getdate( ))--上周select count(*) from [User]where datediff(dd,create_day,(getdate() - datepart(dw,getdate() ))) <= 7--本月select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate())--上月select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate()) - 1学习month(create_day)=month(getdate())本月month(create_day)=month(getdate())-1 上月补充查询今日所有的SELECT * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC下面的可能好些,加了判断是不是本年的,上面的本周,本月会把每年的都查出来查询本月的记录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())sql server:--frist dayselect dateadd(dd,-datepart(dd,getdate())+1,getdate())--last dayselect dateadd(dd,-datepart(dd,getdate()) ,dateadd(mm,1,getdate()))--next month first dayselect dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate()))--本月天数select datediff(dd,dateadd(dd,-datepart(dd,getdate())+1,getdate()),dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate())))orselect datepart(dd,dateadd(dd,-1,dateadd(mm,1,cast(cast(year(getdate()) as varchar)+'-'+cast(month(getdate()) as varchar)+'-01' as datetime))))oracle--本月天数select to_number(to_char(last_day(sysdate),'DD')) from dual加法select sysdate,add_months(sysdate,12) from dual; --加1年select sysdate,add_months(sysdate,1) from dual; --加1月select sysdate,to_char(sysdate+7,'yyyy-mm-dd HH24:MI:SS') from dual; --加1星期select sysdate,to_char(sysdate+1,'yyyy-mm-dd HH24:MI:SS') from dual; --加1天select sysdate,to_char(sysdate+1/24,'yyyy-mm-dd HH24:MI:SS') from dual; --加1小时select sysdate,to_char(sysdate+1/24/60,'yyyy-mm-dd HH24:MI:SS') from dual; --加1分钟select sysdate,to_char(sysdate+1/24/60/60,'yyyy-mm-dd HH24:MI:SS') from dual; --加1秒减法select sysdate,add_months(sysdate,-12) from dual; --减1年select sysdate,add_months(sysdate,-1) from dual; --减1月select sysdate,to_char(sysdate-7,'yyyy-mm-dd HH24:MI:SS') from dual; --减1星期select sysdate,to_char(sysdate-1,'yyyy-mm-dd HH24:MI:SS') from dual; --减1天select sysdate,to_char(sysdate-1/24,'yyyy-mm-dd HH24:MI:SS') from dual; --减1小时select sysdate,to_char(sysdate-1/24/60,'yyyy-mm-dd HH24:MI:SS') from dual; --减1分钟select sysdate,to_char(sysdate-1/24/60/60,'yyyy-mm-dd HH24:MI:SS') from dual; --减1秒。

SQLServer日期查询

SQLServer日期查询

SQLServer⽇期查询SQLServer ⽇期函数⼤全⼀、统计语句1、--统计当前【>当天00点以后的数据】SELECT * FROM 表 WHERE CONVERT(Nvarchar, dateandtime, 111) = CONVERT(Nvarchar, GETDATE(), 111) ORDER BY dateandtime DESC2、--统计本周SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=03、--统计本⽉SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=04、统计当前SELECT * FROM 表 WHERE datediff(day,[dateadd],getdate())=0Select * From table with(nolock) Where Convert(varchar(10),[CreateTime],120) = Convert(varchar(10),getDate(),120)⼆、时间函数1、当前系统⽇期、时间select getdate()2、dateadd 在向指定⽇期加上⼀段时间的基础上,返回新的 datetime 值,例如:向⽇期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003、datediff 返回跨两个指定⽇期的⽇期和时间边界数select datediff(day,'2004-09-01','2004-09-18') --返回:174、datepart 返回代表指定⽇期的指定⽇期部分的整数SELECT DATEPART(month, '2004-10-15') --返回 105、datename 返回代表指定⽇期的指定⽇期部分的字符串SELECT datename(weekday, '2004-10-15') --返回:星期五6、day(), month(),year() --可以与datepart对照⼀下select 当前⽇期=convert(varchar(10),getdate(),120),select 当前时间=convert(varchar(8),getdate(),114),select datename(dw,'2004-10-15')select 本年第多少周=datename(week,'2004-10-15'),select 今天是周⼏=datename(weekday,'2004-10-15')7、求相差天数select datediff(day,'2004-01-01',getdate())8、⼀个⽉第⼀天的SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)9、本周的星期⼀SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)select dateadd(wk,datediff(wk,0,getdate()),6)10、⼀年的第⼀天SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)11、季度的第⼀天SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)12、当天的半夜SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)13、上个⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))14、去年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))15、本⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))16、本年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))17、本⽉的第⼀个星期⼀select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0) 18、查询本周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=019、上周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=120、本⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=021、上⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=1如果要效率,⽤⼀下⽅式22、查询本周注册⼈数select count(*) from [user]where create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112)) 23、上周注册⼈数select count(*) from [user]where create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) 24、本⽉注册⼈数select count(*) from [user]where create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))and create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) 25、上⽉注册⼈数select count(*) from [user]where create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))26、本周select count(*) from Userwhere datediff(dd,create_day,getdate()) <= datepart(dw,getdate())27、上周select count(*) from Userwhere datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 728、本⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate())29、上⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate()) - 130、本周注册⼈数select count(*) from [User]where datediff(dd,create_day,getdate()) <= datepart(dw,getdate())31、上周注册⼈数select count(*) from [User]where datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 732、本⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate())33、上⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate()) - 134、查询今⽇所有SELECT * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC month(create_day)=month(getdate())本⽉month(create_day)=month(getdate())-1 上⽉今天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=0昨天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=17天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=730天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=30本⽉的所有数据:select * from 表名 where DateDiff(mm,datetime类型字段,getdate())=0本年的所有数据:select * from 表名 where DateDiff(yy,datetime类型字段,getdate())=0系统函数:系统函数函数参数/功能getDate ( ) 返回系统⽬前的⽇期与时间DateDiff (interval,date1,date2) 以interval 指定的⽅式,返回date2 与date1两个⽇期之间的差值 date2-date1DateAdd (interval,number,date) 以interval指定的⽅式,加上number之后的⽇期DatePart (interval,date) 返回⽇期date中,interval指定部分所对应的整数值DateName (interval,date) 返回⽇期date中,interval指定部分所对应的字符串名称参数 interval的设定值:值缩写(Sql Server) Access 和 ASP 说明Year Yy yyyy 年 1753 ~ 9999Quarter Qq q 季 1 ~ 4Month Mm m ⽉1 ~ 12Day of year Dy y ⼀年的⽇数,⼀年中的第⼏⽇ 1-366Day Dd d ⽇,1-31Weekday Dw w ⼀周的⽇数,⼀周中的第⼏⽇ 1-7Week Wk ww 周,⼀年中的第⼏周 0 ~ 51Hour Hh h 时0 ~ 23Minute Mi n 分钟0 ~ 59Second Ss s 秒 0 ~ 59Millisecond Ms - 毫秒 0 ~ 999access 和 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年复制代码复制代码Sql 取当天或当⽉的记录表中的时间格式是这样的:2007-02-02 16:50:08.050, 如果直接和当天的时间⽐较,就总得不到准确数据,但是我们可以把这种格式的时间[格式化]成 2007-02-02,也就是只有年-⽉-⽇,然后把当天的时间也格式化成年-⽉-⽇的格式.这样,思路就出来了!我们格式化⽇期要⽤到 Convert()这个函数,要⽤到3个参数,⾸先来格式化当天的⽇期,Convert(varchar(10),getDate(),120)这样我们就可以把当天的⽇期格式化为: 2007-2-2,然后格式化数据库表中的⽇期Convert(varchar(10),TimeFiled,120),最后我们就可以⽤⼀条Sql语句得到当天的数据了.例如:转⾃⽹络程序代码Select * From VIEW_CountBill Where Convert(varchar(10),[time],120) = Convert(varchar(10),getDate(),120)注意:Convert()函数中的各个参数的意义,第⼀个参数,varchar(10)是⽬标系统所提供的数据类型,包括 bigint 和 sql_variant。

sql语句获取今天、昨天、近7天、本周、上周、本月、上月、半年数据

sql语句获取今天、昨天、近7天、本周、上周、本月、上月、半年数据

sql语句获取今天、昨天、近7天、本周、上周、本⽉、上⽉、半年数据01话说有⼀⽂章表article,存储⽂章的添加⽂章的时间是add_time字段,该字段为int(5)类型的,现需要查询今天添加的⽂章总数并且按照时间从⼤到⼩排序,则查询语句如下:02031select * from `article` where date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d');04或者:05061select * from `article` where to_days(date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d')) = to_days(now());07假设以上表的add_time字段的存储类型是DATETIME类型或者TIMESTAMP类型,则查询语句也可按如下写法:0809查询今天的信息记录:10111select * from `article` where to_days(`add_time`) = to_days(now());12查询昨天的信息记录:13141select * from `article` where to_days(now()) – to_days(`add_time`) <= 1;15查询近7天的信息记录:16171select * from `article` where date_sub(curdate(), INTERVAL 7 DAY) <= date(`add_time`);18查询近30天的信息记录:19201select * from `article` where date_sub(curdate(), INTERVAL 30 DAY) <= date(`add_time`);21查询本⽉的信息记录:22231select * from `article` where date_format(`add_time`, ‘%Y%m') = date_format(curdate() , ‘%Y%m');24查询上⼀⽉的信息记录:25261select * from `article` where period_diff(date_format(now() , ‘%Y%m') , date_format(`add_time`, ‘%Y%m')) =1;27对上⾯的SQL语句中的⼏个函数做⼀下分析:2829(1)to_days3031就像它的名字⼀样,它是将具体的某⼀个⽇期或时间字符串转换到某⼀天所对应的unix时间戳,如:323301 mysql> select to_days('2010-11-22 14:39:51');3402 +--------------------------------+3503 | to_days('2010-11-22 14:39:51') |3604 +--------------------------------+3705 | 734463 |3806 +--------------------------------+39074008 mysql> select to_days('2010-11-23 14:39:51');4109 +--------------------------------+4210 | to_days('2010-11-23 14:39:51') |4311 +--------------------------------+4412 | 734464 |4513 +--------------------------------+46可以看出22⽇与23⽇的差别就是,转换之后的数增加了1,这个粒度的查询是⽐较粗糙的,有时可能不能满⾜我们的查询要求,那么就需要使⽤细粒度的查询⽅法str_to_date函数了,下⾯将分析这个函数的⽤法。

SQLSERVER中如何获取日期(一个月的最后一日、一年的第一日等等)

SQLSERVER中如何获取日期(一个月的最后一日、一年的第一日等等)

SQLSERVER中如何获取⽇期(⼀个⽉的最后⼀⽇、⼀年的第⼀⽇等等)⼀、SQL SERVER 中如何获取⽇期(⼀个⽉的最后⼀⽇、⼀年的第⼀⽇等等)这是计算⼀个⽉第⼀天的SQL 脚本:SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) --当⽉的第⼀天SELECT DATEADD(mm, DATEDIFF(mm,0,getdate())-1, 0) --上个⽉的第⼀天SELECT DATEADD(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0)) --当⽉的最后⼀天SELECT DATEADD(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate()), 0)) --上个⽉的最后⼀天我们把这个语句分开来看看它是如何⼯作的。

最核⼼的函数是getdate(),⼤部分⼈都知道这个是返回当前的⽇期和时间的函数。

下⼀个执⾏的函数DATEDIFF(mm,0,getdate())是计算当前⽇期和“1900-01-01 00:00:00.000”这个⽇期之间的⽉数。

记住:时期和时间变量和毫秒⼀样是从“1900-01-01 00:00:00.000”开始计算的。

这就是为什么你可以在DATEDIFF函数中指定第⼀个时间表达式为“0”。

下⼀个函数是DATEADD,增加当前⽇期到“1900-01-01”的⽉数。

通过增加预定义的⽇期“1900-01-01”和当前⽇期的⽉数,我们可以获得这个⽉的第⼀天。

另外,计算出来的⽇期的时间部分将会是“00:00:00.000”。

这个计算的技巧是先计算当前⽇期到“1900-01-01”的时间间隔数,然后把它加到“1900-01-01”上来获得特殊的⽇期,这个技巧可以⽤来计算很多不同的⽇期。

下⼀个例⼦也是⽤这个技巧从当前⽇期来产⽣不同的⽇期。

本周的星期⼀这⾥我是⽤周(wk)的时间间隔来计算哪⼀天是本周的星期⼀。

sql server数据库操作日志查询语句

sql server数据库操作日志查询语句

sql server数据库操作日志查询语句查询SQL Server数据库操作日志的语句可以通过使用系统表sys.fn_dblog来实现。

拓展一下,SQL Server的操作日志(transaction log)是用来记录数据库的所有修改操作的,包括Insert、Update和Delete等操作。

通过查询操作日志可以了解到数据库中发生的所有变更情况,并用于恢复操作或进行故障排除工作。

下面是一个示例查询SQL Server数据库操作日志的SQL语句:```SELECT *FROM sys.fn_dblog(NULL, NULL)```该语句使用了内置的系统函数fn_dblog来查询数据库中的操作日志。

具体使用方法如下:1.使用sys.fn_dblog()函数来查询操作日志,该函数接受两个参数:开始LSN(Log Sequence Number)和结束LSN,NULL表示查询整个日志。

2.查询的结果包含多个字段,包括Transaction ID、Operation、Context和AllocUnitName等。

3.可以通过添加WHERE子句来过滤查询结果,例如只查询某个时间范围内的操作日志。

需要注意的是,SQL Server的操作日志是循环使用的,当日志文件满了之后会自动进行切换。

因此,如果需要查询历史的操作日志,可能需要查看多个日志文件。

另外,SQL Server还提供了更高级的功能来查询和管理操作日志,例如使用日志读取器(Log Reader)来读取操作日志,或使用Change Data Capture(CDC)来跟踪和捕捉数据库变更。

这些功能可以根据实际需求进行深入学习和使用。

sql语句获取本周、上一周、本月数据

sql语句获取本周、上一周、本月数据

sql语句‎获取本周、‎上一周、本‎月数据 .‎分类:‎S QL20‎05 20‎10-04‎-23 1‎6:29 ‎363人阅‎读评论(‎0) 收藏‎举报‎s ql本‎周se‎l ect ‎* fro‎m tb ‎w here‎date‎d iff(‎w eek ‎,时间字‎段 ,ge‎t date‎()) =‎0上‎周se‎l ect ‎* fro‎m tb ‎w here‎date‎d iff(‎w eek ‎,时间字‎段 ,ge‎t date‎()) =‎1下‎周se‎l ect ‎* fro‎m tb ‎w here‎date‎d iff(‎w eek ‎,时间字‎段 ,ge‎t date‎()) =‎-1‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎---‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎--上‎月Se‎l ect ‎* Fro‎m Tab‎l eNam‎e Whe‎r e Da‎t eDif‎f(mm,‎Date‎T imCo‎l, Ge‎t Date‎()) =‎1 -‎-本月‎S elec‎t * F‎r om T‎a bleN‎a me W‎h ere ‎D ateD‎i ff(m‎m, Da‎t eTim‎C ol, ‎G etDa‎t e())‎= 0 ‎--下月‎Sel‎e ct *‎From‎Tabl‎e Name‎Wher‎e Dat‎e Diff‎(mm, ‎G etDa‎t e(),‎Date‎T imCo‎l ) =‎1 ‎昨天‎:date‎a dd(d‎a y,-1‎,getd‎a te()‎)明天‎:date‎a dd(d‎a y,1,‎g etda‎t e())‎上月:‎m onth‎(date‎a dd(m‎o nth,‎-1, ‎g etda‎t e())‎)本月‎:mont‎h(get‎d ate(‎))下‎月:mon‎t h(da‎t eadd‎(mont‎h, 1,‎getd‎a te()‎))-‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎--‎昨天‎S elec‎t * F‎r om T‎a bleN‎a me W‎h ere ‎D ateD‎i ff(d‎d, Da‎t eTim‎C ol, ‎G etDa‎t e())‎= 1 ‎--明天‎Sel‎e ct *‎From‎Tabl‎e Name‎Wher‎e Dat‎e Diff‎(dd, ‎G etDa‎t e(),‎Date‎T imCo‎l) = ‎1 --‎最近七天‎Sele‎c t * ‎F rom ‎T able‎N ame ‎W here‎Date‎D iff(‎d d, D‎a teTi‎m Col,‎GetD‎a te()‎) <= ‎7 --‎随后七天‎-‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎-----‎----‎当前年‎sele‎c t 提‎出日期, ‎d atep‎a rt(y‎e ar,g‎e tdat‎e()) ‎a s 当‎前年 fr‎o m 供方‎资料表‎前一年‎s elec‎t提出‎日期, d‎a tepa‎r t(ye‎a r,ge‎t date‎())-1‎as ‎当前年 f‎r om 供‎方资料表‎后一年‎sele‎c t 提‎出日期, ‎d atep‎a rt(y‎e ar,g‎e tdat‎e())+‎1 as ‎当前年‎f rom ‎供方资料表‎‎。

mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句

mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句

mysql查询今天、昨天、近7天、近30天、本⽉、上⼀⽉的SQL语句mysql查询今天、昨天、近7天、近30天、本⽉、上⼀⽉的SQL 语句这篇⽂章主要介绍了mysql查询今天、昨天、近7天、近30天、本⽉、上⼀⽉的SQL语句,⼀般在⼀些统计报表中⽐较常⽤这个时间段,需要的朋友可以参考下mysql查询今天,昨天,近7天,近30天,本⽉,上⼀⽉数据的⽅法分析总结:话说有⼀⽂章表article,存储⽂章的添加⽂章的时间是add_time字段,该字段为int(5)类型的,现需要查询今天添加的⽂章总数并且按照时间从⼤到⼩排序,则查询语句如下:代码如下:select * from `article` where date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d');或者:代码如下:select * from `article` where to_days(date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d')) = to_days(now());假设以上表的add_time字段的存储类型是DATETIME类型或者TIMESTAMP类型,则查询语句也可按如下写法:查询今天的信息记录:代码如下:select * from `article` where to_days(`add_time`) = to_days(now());查询昨天的信息记录:代码如下:select * from `article` where to_days(now()) – to_days(`add_time`) <= 1;查询近7天的信息记录:代码如下:select * from `article` where date_sub(curdate(), INTERVAL 7 DAY) <= date(`add_time`);查询近30天的信息记录:代码如下:select * from `article` where date_sub(curdate(), INTERVAL 30 DAY) <= date(`add_time`);查询本⽉的信息记录:代码如下:select * from `article` where date_format(`add_time`, ‘%Y%m') = date_format(curdate() , ‘%Y%m');查询上⼀⽉的信息记录:代码如下:select * from `article` where period_diff(date_format(now() , ‘%Y%m') , date_format(`add_time`, ‘%Y%m')) =1;对上⾯的SQL语句中的⼏个函数做⼀下分析:(1)to_days就像它的名字⼀样,它是将具体的某⼀个⽇期或时间字符串转换到某⼀天所对应的unix时间戳,如:代码如下:mysql> select to_days('2010-11-22 14:39:51');+--------------------------------+| to_days('2010-11-22 14:39:51') |+--------------------------------+| 734463 |+--------------------------------+mysql> select to_days('2010-11-23 14:39:51');+--------------------------------+| to_days('2010-11-23 14:39:51') |+--------------------------------+| 734464 |+--------------------------------+可以看出22⽇与23⽇的差别就是,转换之后的数增加了1,这个粒度的查询是⽐较粗糙的,有时可能不能满⾜我们的查询要求,那么就需要使⽤细粒度的查询⽅法str_to_date函数了,下⾯将分析这个函数的⽤法。

SQLSERVER日期函数详细用法

SQLSERVER日期函数详细用法

SQLSERVER⽇期函数详细⽤法1.⼀个⽉第⼀天的Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)2.本周的星期⼀Select DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)3.⼀年的第⼀天Select DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)4.季度的第⼀天Select DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)5.当天的半夜Select DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)6.上个⽉的最后⼀天复制保存Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))7.去年的最后⼀天Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))8.本⽉的最后⼀天Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))9.本年的最后⼀天Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))10.本⽉的第⼀个星期⼀select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)返回当前⽇期和时间通过函数GETDATE(),你可以获得当前的⽇期和时间。

函数GETDATE()可以⽤来作为DATEDIME型字段的缺省值。

这对插⼊记录时保存当时的时间是有⽤的。

要建⽴⼀个表,其中的记录包含有当前的⽇期和时间,可以添加⼀个DATETIME型字段,指定其缺省值为函数GETDATE()的返回值,就象这样:Create TABLE site_log (username VARCHAR(40),useractivity VARCHAR(100),entrydate DATETIME DEFAULT GETDATE())转换⽇期和时间函数GETDATE()的返回值在显⽰时只显⽰到秒。

sqlserver查询本年的每个月的数据

sqlserver查询本年的每个月的数据

sqlserver查询本年的每个⽉的数据⼀、以⼀⾏数据的形式,显⽰本年的12⽉的数据,本⽰例以2017年为例,根据CreateDate字段判断,计算总和,查询语句如下:select sum(case when datepart(month,CreateDate)=1then1else0end) as'1⽉',sum(case when datepart(month,CreateDate)=2then1else0end) as'2⽉',sum(case when datepart(month,CreateDate)=3then1else0end) as'3⽉',sum(case when datepart(month,CreateDate)=4then1else0end) as'4⽉',sum(case when datepart(month,CreateDate)=5then1else0end) as'5⽉',sum(case when datepart(month,CreateDate)=6then1else0end) as'6⽉',sum(case when datepart(month,CreateDate)=7then1else0end) as'7⽉',sum(case when datepart(month,CreateDate)=8then1else0end) as'8⽉',sum(case when datepart(month,CreateDate)=9then1else0end) as'9⽉',sum(case when datepart(month,CreateDate)=10then1else0end) as'10⽉',sum(case when datepart(month,CreateDate)=11then1else0end) as'11⽉',sum(case when datepart(month,CreateDate)=12then1else0end) as'12⽉'from MO_Memberswhere datepart(year,CreateDate)='2017'查询结果如下:⼆、根据当前⽇期,以列的数据形式,显⽰本年的12个⽉的数据,查询语句如下:select date=convert(varchar(10),dateadd(month, 0,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,1,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,2,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,3,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,4,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,5,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,6,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,7,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,8,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,9,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,10,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)union all select date=convert(varchar(10),dateadd(month,11,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120)查询结果如下:⼆、具体应⽤⽰例:以2017为例,查询语句如下:with t as(select date=substring(convert(varchar(10),dateadd(month, 0,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2)union all select date=substring(convert(varchar(10),dateadd(month,1,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,2,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,3,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,4,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,5,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,6,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2)union all select date=substring(convert(varchar(10),dateadd(month,7,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,8,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,9,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,10,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) union all select date=substring(convert(varchar(10),dateadd(month,11,convert(varchar(10),DATEADD(year, DATEDIFF(year,0,getdate()), 0),120)),120),6,2) )select id=ROW_NUMBER()OVER(ORDER BY t1.date),date=t1.date+'⽉',Counts=sum(isnull(t2.counts,0))from t t1left join(select substring(convert(varchar,CreateDate,120),6,2) as CreateDate,count(*) as countsfrom MO_Memberswhere datepart(year,CreateDate)='2017'group by substring(convert(varchar,CreateDate,120),6,2)) t2on t1.date= CreateDategroup by t1.date查询结果如下:。

sqlserver语句中获取月份的方式

sqlserver语句中获取月份的方式

sqlserver语句中获取月份的方式一、介绍在使用SQL Server进行数据查询和分析时,经常需要根据日期字段来进行统计和分组。

其中,获取月份是一个常见的需求。

本文将详细讨论在SQL Server语句中获取月份的几种常用方式,并介绍它们的优缺点和适用场景。

二、DATEPART函数DATEPART函数是SQL Server中获取日期部分的函数之一,可以方便地提取指定日期字段的年份、月份、日等信息。

以下是使用DATEPART函数获取月份的示例代码:SELECT DATEPART(month, date_column) AS monthFROM table_name其中,date_column是包含日期信息的列名,table_name是数据表的名称。

使用DATEPART函数获取月份的优点是简单直接,返回结果为整型,易于处理和计算。

然而,这种方式返回的月份是一个数字,需要根据具体情况进行转换和格式化。

三、MONTH函数MONTH函数是SQL Server中专门用于获取月份的函数,与DATEPART函数类似,也可以提取指定日期字段的月份信息。

以下是使用MONTH函数获取月份的示例代码:SELECT MONTH(date_column) AS monthFROM table_name与DATEPART函数相比,MONTH函数更加简洁明了。

它直接返回月份的整型值,可以直接用于聚合和排序操作。

然而,与DATEPART函数一样,MONTH函数返回的月份依然是一个数字,需要进行进一步转换和格式化。

四、DATENAME函数DATENAME函数是SQL Server中用于获取日期部分的函数之一,可以返回指定日期字段的文本表示。

以下是使用DATENAME函数获取月份的示例代码:SELECT DATENAME(month, date_column) AS monthFROM table_name与前面介绍的DATEPART和MONTH函数不同,DATENAME函数返回的月份是一个文本字符串,可以直接作为结果进行展示。

mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句

mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句

mysql查询今天、昨天、近7天、近30天、本⽉、上⼀⽉的SQL语句mysql查询今天,昨天,近7天,近30天,本⽉,上⼀⽉数据的⽅法分析总结:话说有⼀⽂章表article,存储⽂章的添加⽂章的时间是add_time字段,该字段为int(5)类型的,现需要查询今天添加的⽂章总数并且按照时间从⼤到⼩排序,则查询语句如下:复制代码代码如下:select * from `article` where date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d');或者:复制代码代码如下:select * from `article` where to_days(date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d')) = to_days(now());假设以上表的add_time字段的存储类型是DATETIME类型或者TIMESTAMP类型,则查询语句也可按如下写法:查询今天的信息记录:复制代码代码如下:select * from `article` where to_days(`add_time`) = to_days(now());查询昨天的信息记录:复制代码代码如下:select * from `article` where to_days(now()) – to_days(`add_time`) <= 1;查询近7天的信息记录:复制代码代码如下:select * from `article` where date_sub(curdate(), INTERVAL 7 DAY) <= date(`add_time`);查询近30天的信息记录:复制代码代码如下:select * from `article` where date_sub(curdate(), INTERVAL 30 DAY) <= date(`add_time`);查询本⽉的信息记录:复制代码代码如下:select * from `article` where date_format(`add_time`, ‘%Y%m') = date_format(curdate() , ‘%Y%m');查询上⼀⽉的信息记录:复制代码代码如下:select * from `article` where period_diff(date_format(now() , ‘%Y%m') , date_format(`add_time`, ‘%Y%m')) =1;对上⾯的SQL语句中的⼏个函数做⼀下分析:(1)to_days就像它的名字⼀样,它是将具体的某⼀个⽇期或时间字符串转换到某⼀天所对应的unix时间戳,如:复制代码代码如下:mysql> select to_days('2010-11-22 14:39:51');+--------------------------------+| to_days('2010-11-22 14:39:51') |+--------------------------------+| 734463 |+--------------------------------+mysql> select to_days('2010-11-23 14:39:51');+--------------------------------+| to_days('2010-11-23 14:39:51') |+--------------------------------+| 734464 |+--------------------------------+可以看出22⽇与23⽇的差别就是,转换之后的数增加了1,这个粒度的查询是⽐较粗糙的,有时可能不能满⾜我们的查询要求,那么就需要使⽤细粒度的查询⽅法str_to_date函数了,下⾯将分析这个函数的⽤法。

sqlserver按年季度月周查...

sqlserver按年季度月周查...

sqlserver按年季度月周查询语句(SQL server queries the statement in the annual quarter month)Select month (cast (I _ of the datetime)) from str001 _ LDA where cast (I _ of the datetime) between cast (2010 - 10 - 10 'the datetime) and cast (2010 - 11 - 11' the datetime) group by month (cast (I _ of the datetime))- 按日Select convert (varchar (10), I _, 120) from str001 _ LDA where I _ of between '2010 - 10 - 10' and '2010 - 11 - 11' group by convert (varchar (10), I _, 120)- 按周Select datename (week, I _ of) the weeks, count (I _ in the usercount)From str001 _ LDAWhere I _ of between '2010 - 10 - 10' and '2010 - 11 - 11'Group by datename (week, I _)- 按月Select datename (month, I _ of) the month, count (I _ in the usercount)From str001 _ LDAWhere I _ of between '2010 - 10 - 10' and '2010 - 11 - 11'Group by datename (month, I _)----------------------------------------------------------DatenameSQL datename是返回代表指定日期的指定日期部分的字符串.语法Datename (datepart, date)参数Datepart是指定应返回的日期部分的参数.下表列出了 Microsoft? SQL Server? 识别的日期部分和缩写.Year YY, yyyy quarter QQ, Q month mm, m dayofyear Dy, y day DD, D week wk, WW weekday DW hour HH minute MI, N second SS, s millisecond MS日期部分缩写Weekday (DW) 日期部分返回星期几 (星期天、星期一等).是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式.对 1753 年 1 月 1 日之后的日期用datetime 数据类型.更早的日期存储为字符数据.当输入 datetime 值时, 始终将其放入引号中.因为 smalldatetime 只精确到分钟, 所以当用 smalldatetime 值时, 秒和毫秒总是 0.有关指定日期的更多信息, 请参见 datetime 和 smalldatetime.有关时间值指定的更多信息, 请参见时间格式.如果只指定年份的最后两位数字, 则小于或等于 two digit year cutoff 配置选项的值的最后两位数字的值所在世纪与截止年所在世纪相同.大于该选项的值的最后两位数字的数字所在世纪为截止年所在世纪的前一个世纪.例如, 如果 two digit year cutoff 为 2050 (默认), 则 49 被解释为 2049,50 被解释为 1950.为避免模糊, 请使用四位数字的年份.返回类型Nvarchar注释SQL Server 自动在字符和 datetime 值间按需要进行转换, 例如, 当将字符值与 datetime 值进行比较时.示例此示例从 getdate 返回的日期中提取月份名.Select datename (month, getdate ()) the month name '下面是结果集:Month name------------------------------ February-----------------------------------------------------------------------------一、年度查询查询本年度的数据Select *From the blog _ articleWhere year (from _ unixtime (blogcreatetime)) = year (curdate ())二、查询季度数据查询数据附带季度数Select articleid,季度(from_unixtime(` blogcreatetime `))从` blog_article `其他的同前面部分:查询本季度的数据选择*从blog_article在季度(from_unixtime(blogcreatetime))=季度(CURDATE())三、查询月度数据本月统计(MySQL)SELECT * FROM预订,月(booking_time)=月(curdate())和年(booking_time)=年(curdate())本周统计(MySQL)SELECT * FROM spf_booking在月(booking_time)=月(curdate())和周(booking_time)=周(curdate())四、时间段N天内记录在to_days(now())- to_days(时间字段)< = n当天的记录在日期(时间字段)=日期(now())或在to_days(时间字段)= to_days(now());查询一周:选择*从桌子上date_sub(curdate(),间隔7天)< =日期(column_time);查询一个月:选择*从桌子上date_sub(curdate(),间隔1个月)< =日期(column_time);查询'06-03”到'07-08”这个时间段内所有过生日的会员:从用户那里选择*date_format(生日,“% m %d”)> =“06-03和date_format(生日,“% m %d”)<= 07-08赛季”;统计一季度数据,表时间字段为:节省时间集团通过concat(date_format(节省时间,“Y”),地板((date_format(节省时间,“% m)+ 2)/ 3))或选择年(时间)×10 +((月(时间)- 1)DIV 3)+ 1,计数(*)从餐桌集团的年(时间)×10 +((月(时间)- 1)DIV 3)+ 1;五、分组查询1、年度分组2, monthly grouping3, first according to the annual grouping, and then according to the monthly grouping4, grouped by yearSELECT, count (ArticleId), date_format (FROM_UNIXTIME(`BlogCreateTime`),'%y%m'), sdate, FROM, `blog_article`, group, by, sdateResult:Count (ArticleId) sdateI. annual enquiryQuery data for this yearSELECT *FROM blog_articleWHERE year (FROM_UNIXTIME (BlogCreateTime)) = year (curdate ())Two, query quarterly dataQuery data with quarterly numberSELECT, ArticleId, quarter (FROM_UNIXTIME (`BlogCreateTime`))FROM `blog_article`Others are the same as before: check the data for this quarterSELECT *FROM blog_articleWHERE quarter (FROM_UNIXTIME (BlogCreateTime)) = quarter (curdate ())Three 、 query monthly dataStatistics for this month (MySQL)Select * from, booking, where, month (booking_time) =Month (curdate ()) and year (booking_time) = year (curdate ())Statistics for this week (MySQL)Select * from, spf_booking, where, month (booking_time) =Month (curdate ()) and week (booking_time) = week (curdate ())Four, the time periodN days logWHERE (TO_DAYS) (NOW) - TO_DAYS (field) < = NDay's recordWhere date (time field) =date (now ())orWhere to_days (time field) = to_days (now ());Query week:Select * from table where DATE_SUB (CURDATE), INTERVAL (7 DAY) < = date (column_time);Inquire for a month:Select * from table where DATE_SUB (CURDATE), INTERVAL INTERVAL (1 MONTH) < = date (column_time);Check all members who have passed birthdaysfrom'06-03'to'07-08':SELECT * F从用户那里date_format(生日,“% m %d”)> =“06-03和date_format(生日,“% m %d”)<= 07-08赛季”;统计一季度数据,表时间字段为:节省时间集团通过concat(date_format(节省时间,“Y”),地板((date_format(节省时间,“% m)+ 2)/ 3))或选择年(时间)×10 +((月(时间)- 1)DIV 3)+ 1,计数(*)从餐桌集团的年(时间)×10 +((月(时间)- 1)DIV 3)+ 1;五、分组查询1、年度分组2、月度分组3、先按年度分组,再按月度分组4、按年月分组选择计数(时),date_format(from_unixtime(` blogcreatetime `),“% % m)从` blog_article `组姓名姓名结果:C(艺术icleid )姓名。

SqlServer查询今天,昨天,近七天....数据

SqlServer查询今天,昨天,近七天....数据

SqlServer查询今天,昨天,近七天....数据1今天数据:select * from表名where DateDiff(dd,datetime类型字段,getdate())=02昨天数据:select * from表名where DateDiff(dd,datetime类型字段,getdate())=13 7天内数据:select * from表名where DateDiff(dd,datetime类型字段,getdate())<=74 30天内数据:select * from表名where DateDiff(dd,datetime类型字段,getdate())<=305本⽉数据:select * from表名where DateDiff(mm,datetime类型字段,getdate())=06本年数据:select * from表名where DateDiff(yy,datetime类型字段,getdate())=0789查询今天是今年的第⼏天:select datepart(dayofyear,getDate())10查询今天是本⽉的第⼏天:1. select datepart(dd, getDate())112.select day(getDate())12查询本周的星期⼀⽇期是多少(注意:指定⽇期不能是周⽇,如果是周⽇会计算到下周⼀去。

所以如果是周⽇要减⼀天) SELECT DATEADD(wk,DATEDIFF(wk,0,getdate()),0) 1314查询昨天⽇期:select convert(char,dateadd(DD,-1,getdate()),111) //111是样式号,(100-114)1516查询本⽉第⼀天⽇期:Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) as firstday17查询本⽉最后⼀天⽇期:Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0)) as lastday //修改-3的值会有相应的变化1819本⽉有多少天:select datepart(dd,dateadd(dd,-1,dateadd(mm,1,cast((cast(year(getdate()) as varchar)+'-'+cast(month(getdate()) as varchar)+'-01' ) as datetime ))))2021求两个时间段相差⼏天:select datediff(day,'2012/8/1','2012/8/20') as daysum22在指定的⽇期上±N天:select convert(char,dateadd(dd,1,'2012/8/20'),111) as riqi //输出2012/8/2123在指定的⽇期上±N分钟:select dateadd(mi,-15,getdate()) //查询当前时间15分钟之前的⽇期。

SqlServer对时间(月、周)的操作

SqlServer对时间(月、周)的操作

SqlServer对时间(⽉、周)的操作---上个⽉⽉初第⼀天select CONVERT(varchar(12) , DATEADD(mm,DATEDIFF(mm,0,dateadd(mm,-1,getdate())),0), 112 ) ---上个⽉⽉末最后⼀天select CONVERT(varchar(12),dateadd(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate()),0)), 112 )1.显⽰本⽉第⼀天SELECT DATEADD(mm,DATEDIFF(mm,0,getdate()),0)select convert(datetime,convert(varchar(8),getdate(),120)+'01',120)2.显⽰本⽉最后⼀天select dateadd(day,-1,convert(datetime,convert(varchar(8),dateadd(month,1,getdate()),120)+'01',120))SELECT dateadd(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate())+1,0))3.上个⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0))4.本⽉的第⼀个星期⼀iselect DATEADD(wk,DATEDIFF(wk,0, dateadd(dd,6-datepart(day,getdate()),getdate())),0)5.本年的第⼀天SELECT DATEADD(yy,DATEDIFF(yy,0,getdate()),0)6.本年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate())+1,0))7.去年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate()),0))8.本季度的第⼀天SELECT DATEADD(qq,DATEDIFF(qq,0,getdate()),0)9.本周的星期⼀SELECT DATEADD(wk,DATEDIFF(wk,0,getdate()),0)10.查询本⽉的记录select * from tableName where DATEPART(mm, theDate)=DATEPART(mm, GETDATE()) and DATEPART(yy, theDate)= DATEPART(yy, GETDATE())11.查询本周的记录select * from tableName where DATEPART(wk, theDate) = DATEPART (wk, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())12查询本季的记录 注:其中:GETDATE()是获得系统时间的函数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

在统计的时候,经常会使用SQL查询今天、昨天、本月、本周的记录,我将这些常用的sql语句写在这里。

SQL查询今天的记录:
datediff(day,[Datetime],getdate())=0 &nbsp;把Datetime换为你的相应字段;
SQL查询昨天的记录:
datediff(day,[Datetime],getdate())=1 &nbsp;把Datetime换为你的相应字段,getdate()-Datetime即为时间差。

&nbsp;本月记录:
SELECT * FROM 表WHERE datediff(month,[dateadd],getdate())=0
&nbsp;本周记录:
SELECT * FROM 表WHERE datediff(week,[dateadd],getdate())=0
本日记录:
SELECT * FROM 表WHERE datediff(day,[dateadd],getdate())=0
GetDate函数的使用方法
函数参数/功能
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指定部分所对应的字符串名称
更多信息请查看IT技术专栏。

相关文档
最新文档