我是靠谱客的博主 干净奇迹,最近开发中收集的这篇文章主要介绍oracle在where条件中关于索引字段的使用注意事项,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本博客只做日常技术经验总结,不涉及真实内容,以下字段均为虚拟。

提取5日内APP自营订单按照支付方式分别计算订单数和用户数

在提数前,查看了表的索引字段,发现时间范围限制字段也在其中,所以弃用平时比较常见的char(created_at,'yyyy-MM-dd'),用大于小于某时间节点来代替函数的使用,极大的加快了运算时间
 

select 
to_char(created_at,'yyyy-MM-dd') as order_date, 
COUNT(case when pay_type=411111 then ID END)  as 使用云闪付支付订单数,
COUNT(distinct case when pay_type=412455 then user_id END)  as 使用云闪付支付用户数,
COUNT(case when pay_type=398698 then ID END)  as 使用applepay支付订单数,
COUNT(distinct case when pay_type=399090 then user_id END)  as 使用applepay支付用户数,
COUNT(distinct user_id) as APP整体自营购物用户数,
COUNT(ID)  as APP整体自营购物用户数
from 
(
select ID,user_id,pay_type,CREATED_AT,order_source,order_platform from c_order1
union all
select ID,user_id,pay_type,CREATED_AT,order_source,order_platform from c_order2
)
where order_source  in  (...)
and order_platform in (...)
and CREATED_AT>=to_date('2022-06-16 00:00:00','YYYY-MM-DD HH24:MI:SS')
and CREATED_AT<=to_date('2022-06-20 23:59:59','YYYY-MM-DD HH24:MI:SS')
group by to_char(created_at,'yyyy-MM-dd');

最后

以上就是干净奇迹为你收集整理的oracle在where条件中关于索引字段的使用注意事项的全部内容,希望文章能够帮你解决oracle在where条件中关于索引字段的使用注意事项所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部