程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> SQL中碰到多條雷同內容只取一條的最簡略完成辦法

SQL中碰到多條雷同內容只取一條的最簡略完成辦法

編輯:MSSQL

SQL中碰到多條雷同內容只取一條的最簡略完成辦法。本站提示廣大學習愛好者:(SQL中碰到多條雷同內容只取一條的最簡略完成辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL中碰到多條雷同內容只取一條的最簡略完成辦法正文


SQL中常常碰到以下情形,在一張表中有兩筆記錄根本完整一樣,某個或某幾個字段有些許差異,

這時候候能夠須要我們踢出這些有差異的數據,即兩條或多筆記錄中只保存一項。

以下:表timeand

https://www.aspphp.online/shujuku/UploadFiles_3118/201707/2017072811312414.jpg

針對time字段雷同時有分歧total和name的情況,每當碰到雷同的則只取個中一條數據,最簡略的完成辦法有兩種

1、select time,max(total) as total,name from timeand group by time;//取記載中total最年夜的值

https://www.aspphp.online/shujuku/UploadFiles_3118/201707/2017072811312488.jpg

或 select time,min(total) as total,name from timeand group by time;//取記載中total最小的值

https://www.aspphp.online/shujuku/UploadFiles_3118/201707/2017072811312464.jpg

上述兩種計劃都有個缺陷,就是沒法辨別name字段的內容,所以普通用於只要兩條字段或其他字段內容完整分歧的情形

2、select * from timeand as a where not exists(select 1 from timeand where a.time = time and a.total<total);

https://www.aspphp.online/shujuku/UploadFiles_3118/201707/2017072811312411.jpg

其中計劃消除了計劃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中碰到多條雷同內容只取一條的最簡略完成辦法的全體內容,願望能給年夜家一個參考,也願望年夜家多多支撐。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved