SQL中碰到多條雷同內容只取一條的最簡略完成辦法。本站提示廣大學習愛好者:(SQL中碰到多條雷同內容只取一條的最簡略完成辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL中碰到多條雷同內容只取一條的最簡略完成辦法正文
SQL中常常碰到以下情形,在一張表中有兩筆記錄根本完整一樣,某個或某幾個字段有些許差異,
這時候候能夠須要我們踢出這些有差異的數據,即兩條或多筆記錄中只保存一項。
以下:表timeand
針對time字段雷同時有分歧total和name的情況,每當碰到雷同的則只取個中一條數據,最簡略的完成辦法有兩種
1、select time,max(total) as total,name from timeand group by time;//取記載中total最年夜的值
或 select time,min(total) as total,name from timeand group by time;//取記載中total最小的值
上述兩種計劃都有個缺陷,就是沒法辨別name字段的內容,所以普通用於只要兩條字段或其他字段內容完整分歧的情形
2、select * from timeand as a where not exists(select 1 from timeand where a.time = time and a.total<total);
其中計劃消除了計劃1中name字段禁絕確的成績,取的是total最年夜的值
下面的例子中是只要一個字段不雷同,假設有兩個字段湧現雷同呢?請求查處第三個字段的最年夜值該若何做呢?
其實很簡略,在本來的基本上略微做下修正便可:
本來的SQL語句:
select * from timeand as a where not exists(select 1 from timeand where a.time = time and a.total<total);
可修正為:
select * from timeand as a where not exists(select 1 from timeand where a.time = time and (a.total<total or (a.total=total and a.outtotal<outtotal)));
個中outtotal是別的一個字段,為Int類型
以上就是SQL中碰到多條雷同內容只取一條的最簡略完成辦法的全體內容,願望能給年夜家一個參考,也願望年夜家多多支撐。