成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL騷操作,一條SQL 統計近 7天、30天、全部的訂單量

數據庫 其他數據庫
我用了一個 4w 多訂單數據的用戶測試了一下,執行時間是 0.5s ,問題主要出在臨時表,一旦數據量起來就不太行,但是暫時沒接數倉就先這樣頂著了,就前期用用。

你好,我是yes。

最近在搞新項目,一直在迭代,這期接到個新需求,統計商戶近 1天、7天、30天、全部的訂單量。

一般而言這種統計類需求都不會直接查庫,而是交由數倉同學統計,然后回寫到業務表或者業務同學直接讀數倉表。

但是由于這是新項目,還沒接數倉,并且量還沒起來,所以這期就將就著先直接查庫實現。

那么問題來了,這 SQL 咋寫呢?

直接看簡化的表結構:

CREATE TABLE order (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `order_no` varchar(32) NOT NULL COMMENT '訂單號',
  `user_id` bigint NOT NULL COMMENT '用戶id',
  `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創建時間',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `idx_userid_createtime` (`user_id`,`create_time`) USING BTREE
)

今天是 2023-09-12 ,如果我們要統計近 1 天的訂單量,那么 SQL 很簡單:

SELECT count(*) FROM order where user_id = 'xx' and time_create >'2023-09-12 00:00:00'

同理 7天、30天

SELECT count(*) FROM order where user_id = 'xx' and time_create >'2023-09-06 00:00:00'

SELECT count(*) FROM order where user_id = 'xx' and time_create >'2023-08-14 00:00:00'

還有全部

SELECT count(*) FROM order where user_id = 'xx'

但是這樣一來需要查四次數據庫!能不能整個花活,把它壓縮成一條 SQL 一次性查詢呢?

動腦瓜子刮了刮,還真行!看下面這條 SQL:

SELECT statistics, count(*) from (
SELECT CASE 
 WHEN time_create > '2023-09-12 00:00:00' THEN '1'
 WHEN time_create > '2023-09-06 00:00:00' THEN '7'
 WHEN time_create > '2023-08-14 00:00:00' THEN '30'
 ELSE
  'all'
END as statistics
from `order` where user_id = 'xxx'
) temp GROUP BY statistics;

執行結果如下:

思路就是利用 case when 先給對應時間數據打個標記,存放在臨時表,然后通過 group by 統計。

我用了一個 4w 多訂單數據的用戶測試了一下,執行時間是 0.5s ,問題主要出在臨時表,一旦數據量起來就不太行,但是暫時沒接數倉就先這樣頂著了,就前期用用。

突然回想起前公司那時候沒招數據同學,讓我去整 BI, 那 SQL 寫的天花亂墜,感覺把一輩子的 SQL 都寫完了,SQL Boy 也不容易啊。

責任編輯:武曉燕 來源: yes的練級攻略
相關推薦

2025-05-20 00:00:00

2025-05-12 08:27:25

2024-07-29 09:49:00

SQLMySQL執行

2021-04-16 07:04:53

SQLOracle故障

2023-03-26 22:42:02

SQL關聯索引

2022-02-11 14:43:53

SQL語句C/S架構

2020-07-01 09:07:52

SQL索引語句

2011-02-23 13:26:01

SQL查詢優化

2024-12-17 06:20:00

MySQLSQL語句數據庫

2020-04-17 14:16:10

SQL數據庫HTTP

2022-05-31 13:58:09

MySQL查詢語句

2023-02-26 23:31:01

SQL數據庫

2024-01-03 17:42:32

SQL數據庫

2019-04-28 09:56:15

程序員互聯網脫發

2021-02-09 09:50:21

SQLOracle應用

2020-10-26 08:02:28

SQL慢查詢索引

2015-03-25 19:15:08

2021-06-07 08:37:03

SQL 查詢語句

2011-08-16 11:13:05

SQL ServerSQL語句前n條訂單

2021-08-03 08:41:18

SQLMysql面試
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 狠狠骚 | 狠狠爱视频 | 久久精品视频播放 | 99精品国自产在线观看 | 国产精品日本一区二区在线播放 | 国产黄色精品在线观看 | 青娱乐自拍 | 自拍偷拍亚洲视频 | 久久精品综合 | www.日韩免费| 97超在线视频 | 在线看av的网址 | 中文字幕伊人 | 久久成人一区 | 国产精品一区二区不卡 | 国产三级大片 | 国内精品久久久久久久影视简单 | 久久九九网站 | 国产aaaaav久久久一区二区 | 天堂一区二区三区四区 | www久久爱 | 国产福利视频导航 | 国产日韩电影 | 国产日韩欧美在线 | 伊人成人免费视频 | 黑人精品欧美一区二区蜜桃 | 综合国产 | 中文字幕免费视频 | 亚洲国产一区二区三区在线观看 | 日韩中文字幕一区二区 | 亚洲精品区 | 99久久婷婷 | 国产精品国产精品国产专区不卡 | 午夜精品| 亚洲欧美日韩精品久久亚洲区 | 精品久久精品 | 国产亚洲精品成人av久久ww | 天天成人综合网 | 天天精品综合 | 国产99久久久久 | 亚洲成人高清 |