时间SQL查询大全

 //查询15天之前得数据(modifydate)是数据库得时间字段格式yyyy-MM-dd hh:mm:ss
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 15 DAY) > date(modifydate);

//删除十五天之前的数据(log_time_YMD是数据库得时间字段格式yyyy-MM-dd hh:mm:ss
 1:delete From 表名 where DATE_SUB(CURDATE(), INTERVAL 15 DAY) > date(log_time_YMD);

//删除七天之前的数据(modifydate是数据库得时间字段格式yyyy-MM-dd hh:mm:ss
2:delete From 表名 where DATE(modifydate) <= DATE(DATE_SUB(NOW(),INTERVAL 7 day))

//时间区间查询
1:select * from 表名 where 日期列 >= to_date('2015-10-20 00:00:00','yyyy-mm-dd hh24:mi:ss') and t.日期列 <= to_date('2015-10-20 23:59:59','yyyy-mm-dd hh24:mi:ss')
//时间区间查询
2:select * from 表名 where 日期列 between to_date('2015-10-20 00:00:00','yyyy-mm-dd hh24:mi:ss')and to_date('2015-10-20 23:59:59','yyyy-mm-dd hh24:mi:ss')


//如果数据库得时间格式是yyyyMMdd --19900808 sdate 时间字段) (?客户传过来的时间)
 SELECT * FROM 表名 WHERE 1 = 1 and 表名.时间字段>= ? and 表名.时间字段 >= ?

//查询今天得全部数据
 select * from 表名 where to_days(时间字段名) = to_days(now());

//查询昨天全部得数据
 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( modifydate) = 1

查询本月得数据
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )

查询上个月的数据
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1

//查询本季度数据
select * from 表名 where QUARTER(数据库字段)=QUARTER(now());

//查询上季度数据
select * from 表名 where QUARTER(时间字段)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

//查询本年数据
select * from 表名 where YEAR(时间字段)=YEAR(NOW());

查询上年数据
select * from 表名 where year(时间字段)=year(date_sub(now(),interval 1 year));

//查询当前这周得数据
 SELECT * FROM 表名 WHERE YEARWEEK(date_format(时间字段,'%Y-%m-%d')) = YEARWEEK(now());

//查询上周数据
SELECT *  FROM 表名 WHERE YEARWEEK(date_format(时间字段,'%Y-%m-%d')) = YEARWEEK(now())-1;

//查询上一个月得数据
select *  from 表名 where date_format(时间字段,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m')

//查询距离当前现在6个月的数据
select * from 表名 where 时间字段 between date_sub(now(),interval 6 month) and now()

以上除非特殊说明其余的时间字段都是yyyy-MM-dd HH:mm:ss格式






 
 








 
 
 



 
 



 
 


转载于:https://www.cnblogs.com/ysySelf/p/10930420.html

1.--查询当: select * from [TABLE] where DateDiff(dd,[dateadd],getdate())=0 2.--查询24小时内的: select * from [TABLE] where DateDiff(hh,[dateadd],getDate())<=24 3.--本月记录 SELECT * FROM [TABLE] WHERE datediff(month,[dateadd],getdate())=0 4.--本周记录 SELECT * FROM [TABLE] WHERE datediff(week,[dateadd],getdate())=0 5.--当前系统日期、时间 select getdate() 6.--在向指定日期加上一段时间的基础上,返回新的 datetime 值(例如:向日期加上2 ) select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000 7.--返回跨两个指定日期的日期和时间边界数。 select datediff(day,'2004-09-01','2004-09-18') --返回:17 8.--返回代表指定日期的指定日期部分的整数。 SELECT DATEPART(month, '2004-10-15') --返回 10 9.--返回代表指定日期的指定日期部分的字符串 SELECT datename(weekday, '2004-10-15') --返回:星期五 10.--day(), month(),year() --可以与datepart对照一下 select 当前日期=convert(varchar(10),getdate(),120),当前时间=convert(varchar(8),getdate(),114) 11.--返回星期几 select datename(dw,'2004-10-15') 12.--返回周和星期 select 本年第多少周=datename(week,'2004-10-15'),今是周几=datename(weekday,'2004-10-15') 13.--计算到2个时间之间间隔的工作日和工作小时 CREATE FUNCTION dbo.WORKDAYDIFF(@fromDate datetime, @thruDate datetime) RETURNS int AS BEGIN declare @result int set @fromDate = dateadd(day, case when datepart(weekday, @fromDate); % 7 <= 1 then 2 - datepart(weekday, @fromDate); % 7 else 0 end, @fromDate); set @thruDate = dateadd(day, case when datepart(weekday, @thruDate); % 7 <= 1 then -1 - datepart(weekday, @thruDate); % 7 else 0 end, @thruDate); set @result = datediff(hour,@fromDate,@thruDate); / 24 - datediff(week,@fromDate,@thruDate); * 2 if(@result < 0); set @result = 0 return @result END 14.计算哪一是本周的星期一 SELECT DATEADD(week, DATEDIFF(week,'1900-01-01',getdate()), '1900-01-01') -- 返回2006-11-06 00:00:00.000 或 SELECT DATEADD(week, DATEDIFF(week,0,getdate()),0) 15.当前季度的第一 SELECT DATEADD(quarter, DATEDIFF(quarter,0,getdate()), 0) —返回2006-10-01 00:00:00.000 16.如何取得某个月的数 SELECT Day(dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1,0))) —返回28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值