mysql根据统计值排序

公司有个需求,需要对用户的购买数和分销用户数进行排序,而现在的统计是根据查询遍历出来的,首先想到的是用脚本实现,但是考虑到用户表的数据量25万 就放弃了,于是想试试mysql能不能完成这样的工作,下面就是写出来的sql语句,大家可以参考一下

SELECT `id`,`create_time`,(SELECT count(id) FROM my_order AS o WHERE `user_id` = u.id AND `status` = 3 AND `type` = 0 LIMIT 0,1) as buy,(SELECT count(id) FROM my_divid_order AS d WHERE `user_id` = u.id AND `status` <> 0 LIMIT 0,1) as divide FROM passport AS u ORDER BY `buy` DESC LIMIT 0,20

美化一下

SELECT
	`id`,
	`create_time`,
	(SELECT count( id ) FROM my_order AS o WHERE `user_id` = u.id  AND `status` = 3 AND `type` = 0 LIMIT 0,1 ) AS buy,
	(SELECT count( id ) FROM my_divid_order AS d WHERE `user_id` = u.id AND `status` <> 0 LIMIT 0,1 ) AS divide 
FROM
	passport AS u 
ORDER BY
	`buy` DESC 
	LIMIT 0,
	20

 

转载于:https://my.oschina.net/colinadmin/blog/3102719

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值