mysql一些较为复杂的用法(更新中)

1、查询表7天的记录(t_company 表名,create_time 时间字段名,CURDATE() 当前系统时间)

SELECT * FROM t_company where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(create_time)

2、查询表30天的记录(t_company 表名,create_time 时间字段名,CURDATE() 当前系统时间)

SELECT * FROM t_company where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(create_time)

3、查询表数据,并且根据时间字段的年月日分组,通过GROUP BY DATE_FORMAT(create_time,"%Y%m%d")

SELECT COUNT(id),create_time FROM t_company	where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(create_time) GROUP BY  DATE_FORMAT(create_time,"%Y%m%d")

在这里插入图片描述
4、按天统计数据,如果当天没有记录,则统计为0
参考链接
参考链接

t_company表名,t_operation_log表名,create_time 时间字段名

SELECT t1.day,COALESCE(t2.num,0) as num FROM 
	(SELECT 
	@cdate := DATE_ADD(@cdate, INTERVAL - 1 DAY) DAY FROM (SELECT @cdate := DATE_ADD(CURDATE(), INTERVAL + 1 DAY) FROM 
	t_company) t0 LIMIT 30) t1 
	LEFT JOIN (
	SELECT count(id) num,DATE(t_operation_log.create_time) DAY 
	FROM t_operation_log GROUP BY  DATE_FORMAT(create_time,"%Y%m%d"
	) ORDER BY create_time DESC) t2 ON t2.day = t1.day GROUP BY t1.day

5、Mysql实行模糊查询,一个输入值匹配多个字段
参考链接

select * from 表名 where concat(字段1,字段2,) like '%关键字%'

6、查询两张表,不一样的数据

select * from  B where (select count(1) from  A where A.id = B.id) = 0
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值