sql实际开发使用sql语句

查询一天之内的数据时间从今天的零0点0分0秒开始—到23点59分59秒结束,查询完在给他按更新时间排个序

SELECT * FROM 表名 WHERE 当前表时间字段名 >= DATE_FORMAT(CURDATE(),'%Y-%m-%d %H:%i:%s')AND 当前表时间字段名 <= DATE_SUB( DATE_ADD(CURDATE(), INTERVAL 1 DAY),INTERVAL 1 SECOND)ORDER BY 时间字段名 ASC

如:

#查询今天收入的金额,type类型为1的时候为收入
SELECT SUM(r_money) FROM `transfer_record`  WHERE r_time >= DATE_FORMAT(CURDATE(),'%Y-%m-%d %H:%i:%s')
AND r_time <= DATE_SUB( DATE_ADD(CURDATE(), INTERVAL 1 DAY),INTERVAL 1 SECOND) AND r_type =1 AND uid=1
ORDER BY r_time ASC
#查询今天支出的金额 type类型为0的时候为支出
SELECT SUM(r_money) FROM `transfer_record`  WHERE r_time >= DATE_FORMAT(CURDATE(),'%Y-%m-%d %H:%i:%s')
AND r_time <= DATE_SUB( DATE_ADD(CURDATE(), INTERVAL 1 DAY),INTERVAL 1 SECOND) AND r_type =0 AND uid=1
查询在多少秒内的数据
SELECT count( * ) AS c, sum( if( logusertype = 2, logusertype, 0 ) ) / 2 AS a, sum( if( logusertype = 3, logusertype, 0 ) ) /3 AS bFROM testlog WHERE UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP( logendtime )<=30
查询往前7天的数据:
select * from 数据表  where  DATE_SUB(CURDATE(), INTERVAL 7 DAY) <=  你要判断的时间字段名 
查询一周内的数据:
#查询一周内的数据
SELECT * FROM `transfer_record`(表名) a WHERE DATE_SUB(CURDATE(), INTERVAL 7 DAY)  <= DATE(a.r_time) (表的时间字段)
查询上周7天的记录
SELECT * FROM `表名` WHERE YEARWEEK(DATE_FORMAT(时间字段名,'%Y-%m-%d')) = YEARWEEK(NOW())-1;
查询往前30天的数据:
select * from 数据表  where  DATE_SUB(CURDATE(), INTERVAL 30 DAY) <=  你要判断的时间字段名  
查询在某段日期之间的数据:
select * from 数据表  where 时间字段名 BETWEEN '2016-02-01' AND '2016-02-05'  
查询往前3个月的数据:
select * from 数据表  where 时间字段名 BETWEEN DATE_SUB(NOW(),INTERVAL 3 MONTH) AND NOW()  
查询六个月的数据
SELECT * FROM 表名 WHERE 时间字段名 between date_sub(now(),interval 6 month) and now();
查询往前一年的数据:
select * from 数据表  where 时间字段名 BETWEEN DATE_SUB(NOW(),INTERVAL 1 YEAR) AND NOW()  
查询一年的数据
-- 查询一年的
SELECT * FROM `transfer_record` WHERE condition1(条件1:表的时间字段名) AND condition2(条件2:表的时间字段名) AND DATE_SUB(CURDATE(), INTERVAL 1 YEAR) <= DATE(字段名);
-- 查询一年的
SELECT * FROM 表名  WHERE YEAR(create_date)=YEAR(NOW());

查询上年的数据
-- 查询上年的
SELECT * FROM 表名 WHERE YEAR(create_date)=YEAR(DATE_SUB(NOW(),INTERVAL 1 YEAR));
查询本月的数据
select * from 数据表 where DATE_FORMAT(时间字段名,'%Y-%m')=DATE_FORMAT(NOW(),'%Y-%m') 
查询上月的数据
select * from 数据表 where DATE_FORMAT(时间字段名,'%Y-%m')=DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL 1 MONTH),'%Y-%m')
查询本周的数据
select * from 数据表 where YEARWEEK(DATE_FORMAT(时间字段名,'%Y-%m-%d')) = YEARWEEK(NOW())  
#或者
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )
查询上周数据
select * from 数据表 where YEARWEEK(DATE_FORMAT(CREATE_TIME,'%Y-%m-%d')) = YEARWEEK(NOW())-1  
#或者
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
查询昨天的数据(只有昨天的)还有只包括昨天和今天的
-- 只有昨天的
SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())=-1; 
-- 同理,查询前天的就是-2-- 包括昨天和今天的
SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1
查询本季的和上季的数据
-- 本季度
SELECT * FROM 表名 WHERE QUARTER(create_date)=QUARTER(NOW());
-- 上季度
SELECT * FROM 表名 WHERE QUARTER(create_date)=QUARTER(DATE_SUB(NOW(),INTERVAL 1 QUARTER));
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值