2012-10-02 67 views
0

我不知道如何寫這個問題的標題,但我需要的是一個查詢,返回具有特定值的N記錄是什麼。查詢數據庫找到第N個記錄

我擁有的桌子已超過5個。2M記錄

中的記錄是類似於:

  • 會話(字符串,主索引)
  • CUSTOMER_ID(INT,索引)
  • 點擊(INT,索引)
  • ORDER_NUMBER(INT,索引)
  • date_entry(datetime,索引)
  • 許多其他字段

什麼,我需要知道的是相同的客戶多少次登錄到該網站(不同的會話)在訂購前(ORDER_NUMBER是0,除非訂單被該屆會議期間放置)

的樣本數據可以(簡化數據)

 
session | c_id | clicks | ord_num |   entry  | 
abc  | 123 | 2 | 0  | 2012-08-01 00:00:00 | 
cde  | 456 | 2 | 0  | 2012-08-01 00:00:01 | 
efg  | 457 | 2 | 0  | 2012-08-01 00:00:02 | 
hij  | 123 | 5 | 0  | 2012-08-01 00:00:03 | 
kod  | 986 | 10 | 0  | 2012-08-01 00:00:04 | 
wdg  | 123 | 2 | 9876 | 2012-08-01 00:00:05 | 
qwe  | 123 | 2 | 0  | 2012-08-01 00:00:06 | 
wvr  | 986 | 12 | 8656 | 2012-08-01 00:00:07 | 

我要的是一個查詢,顯示了類似於:

  • 項 - 日期輸入
  • 個tot_sess - 會話總數
  • tot_cust - 客戶總數
  • 1sess - customer1表只有一個區段
  • 2sess - 客戶與2屆
  • 3sess - 客戶3屆
  • 4sess - 客戶與4屆
  • more4sess - 客戶提供超過4屆
  • order1sess - 客戶,關於第一屆會議下令
  • 個order2sess - 即第二屆訂購客戶
  • order3sess - 即第三屆會議下令客戶
  • order4sess - 即第四屆會議下令客戶
  • orderMore4Sess - 客戶第四屆會議後,下令
 
entry   |tot_sess|tot_cust| 1sess | 2sess | 3sess | 4sess | more4sess | order1sess | order2sess | order3sess | order4sess | orderMore4Sess | 
2012-08-01 | 8 | 4 | 2 | 1 | 0 | 1 | 0  |  0 | 1  |  1  |  0  |  0   | 

我已經能夠獲得有關與下面的查詢會話的信息:

SELECT 
    t.`date_entry`, 
    COUNT(sess) `cust`, 
    SUM(sess) `session`, 
    COUNT(IF(sess>1,sess,NULL)) `more than once`, 
    COUNT(IF(sess=1,sess,NULL)) `one`, 
    COUNT(IF(sess=2,sess,NULL)) `two`, 
    COUNT(IF(sess=3,sess,NULL)) `three`, 
    COUNT(IF(sess=4,sess,NULL)) `four`, 
    COUNT(IF(sess>4,sess,NULL)) `more`, 
    ROUND(COUNT(IF(sess>1,sess,NULL))/COUNT(sess),2) `perc > 1`, 
    ROUND(COUNT(IF(sess>2,sess,NULL))/COUNT(sess),2) `perc > 2`, 
    ROUND(COUNT(IF(sess>3,sess,NULL))/COUNT(sess),2) `perc > 3`, 
    ROUND(COUNT(IF(sess>4,sess,NULL))/COUNT(sess),2) `perc > 4` 
FROM 
(
SELECT 
    `customer_id`, 
    COUNT(`session`) `sess`, 
    DATE(`date_entry`) `date_entry` 
FROM `customer_activity_log` 
WHERE 
    `clicks` > 1 
    AND `customer_id` > 0 
    AND `date_entry` > '2012-08-01' 
    AND subsite_id <=1 
GROUP BY `date_entry`, `customer_id` 
) t 
GROUP BY date_entry 

一旦我有了這些,我還需要以不同的方式查看數據,例如,如果客戶123在2012-01-01第一次顯示,然後又回來了15次,並將訂單放置在2012年-08-01,然後又回來了5次,並在2012-10-12又下了一個訂單,我將需要一個查詢,不會受約會日期的約束,但僅限於客戶,換句話說,約束date_entry將被刪除

我希望它是有道理的

回答

2
SELECT e    AS entry, 
     SUM(sessions) AS tot_sess, 
     COUNT(*)  AS tot_cust, 
     SUM(sessions=1) AS 1sess, 
     SUM(sessions=2) AS 2sess, 
     SUM(sessions=3) AS 3sess, 
     SUM(sessions=4) AS 4sess, 
     SUM(sessions>4) AS more4sess, 
     SUM(orders =1) AS order1sess, 
     SUM(orders =2) AS order2sess, 
     SUM(orders =3) AS order3sess, 
     SUM(orders =4) AS order4sess, 
     SUM(orders >4) AS orderMore4Sess 
FROM (
    SELECT b.e, b.c_id, b.sessions, COUNT(a.entry) AS orders 
    FROM customer_activity_log a RIGHT JOIN (
    SELECT DATE(entry) AS e, c_id, COUNT(*) AS sessions, 
      MIN(IF(ord_num=0,NULL,entry)) AS o 
    FROM  customer_activity_log 
    GROUP BY e, c_id 
) b ON a.c_id = b.c_id AND DATE(a.entry) = b.e AND a.entry <= b.o 
    GROUP BY b.e, b.c_id 
) t 

請參閱sqlfiddle

+0

謝謝。我將不得不努力工作並嘗試加快速度,但這是一個很好的問題。 – Fabrizio