取出重复记录的第一条
這幾天在查詢購買記錄,其中一個需求就是查出來客戶首次購買的產(chǎn)品時間和產(chǎn)品名稱。說白了,就是在一段時間內(nèi),去取出來用戶的第一次購買記錄,再清楚一些就是在一堆重復的記錄中取出第一條購買記錄。
這個問題捉只讓我困擾了一段時間,自己最存儲過程還是不能駕輕就熟,所以還是得按照傳統(tǒng)的方法來進行查詢了。
要查詢的記錄如下:
而我們要取出來的記錄如下:
事實上,這樣的記錄如果取出來第一條記錄還是比較好取的,因為這里面有購買時間,我們可以根據(jù)購買時間,來取出首次購買的記錄。同一個用戶,購買的時間最早的,就是首次購買產(chǎn)品。
mysql> select account,itemid,buytime from testdup
??? -> where buytime in (select min(buytime)
??? -> from testdup group by account);
得到的結果如下
+-------------+----------+---------------------+
| account???? | itemid?? | buytime??????????????????? |
+-------------+----------+---------------------+
| zoinzone??? ?? | 2686977? | 2011-06-25 18:15:26 |
| llCoKell????? ???| 65599??? | 2011-06-14 00:44:36 |
| eventcso010 | 3735553? | 2011-06-23 15:34:33 |
| eventcso004 | 18939907 | 2011-06-24 18:33:35 |
+-------------+----------+---------------------+
4 rows in set (0.00 sec)
此外,還有的情況是,沒有這樣一個時間的標記項,讓我們?nèi)〕鲇涗浿忻總€重復記錄的第一條,我們可以新建一列ID,自動累加,如下:
mysql> select * from testdup;
+----+-------------+----------+---------------------+
| id | account???? | itemid?? | buytime???????????? |
+----+-------------+----------+---------------------+
|? 1 | zoinzone??? | 655361?? | 2011-06-25 18:16:14 |
|? 2 | zoinzone??? | 2686977? | 2011-06-25 18:15:26 |
|? 3 | llCoKell??? | 6691703? | 2011-06-16 19:30:48 |
|? 4 | llCoKell??? | 65599??? | 2011-06-14 00:44:36 |
|? 5 | eventcso010 | 3735553? | 2011-06-23 15:34:33 |
|? 6 | eventcso010 | 3735553? | 2011-06-26 17:24:25 |
|? 7 | eventcso004 | 18939907 | 2011-06-24 18:33:35 |
+----+-------------+----------+---------------------+
7 rows in set (0.02 sec)
我們可以通過ID來取出我們想要的記錄:
mysql> select * from testdup
??? -> where id in (select min(id)
??? -> from testdup group by account);
+----+-------------+----------+---------------------+
| id | account???? | itemid?? | buytime???????????? |
+----+-------------+----------+---------------------+
|? 1 | zoinzone??? | 655361?? | 2011-06-25 18:16:14 |
|? 3 | llCoKell??? | 6691703? | 2011-06-16 19:30:48 |
|? 5 | eventcso010??? | 3735553? | 2011-06-23 15:34:33 |
|? 7 | eventcso004??? | 18939907 | 2011-06-24 18:33:35 |
+----+-------------+----------+---------------------+
4 rows in set (0.00 sec)
轉載于:https://www.cnblogs.com/yuyang-DataAnalysis/archive/2011/08/02/2124490.html
總結
以上是生活随笔為你收集整理的取出重复记录的第一条的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 用较早版本的APIs实现抽象类
- 下一篇: Linux忘记root密码怎么办?