當前位置:首頁 » 編程語言 » sql去掉重復

sql去掉重復

發布時間: 2022-01-11 17:10:29

Ⅰ 怎樣通過sql去除部分重復的數據

比如有新聞表News,欄位有NewsId,NewsTitle等等,那麼如果想把NewsTitle相同的記錄只保留NewsId最大的一條,其餘的重復數據全部清掉,那麼用這個sql:

DELETEa
FROMNewsa
WHEREEXISTS(SELECT1
FROMNewsb
WHEREa.NewsTitle=b.NewsTitle
ANDb.NewsId>a.NewsId))

Ⅱ 【sql去除重復數據】

select
DISTINCT finger,width,height,size,type
form image
order by finger,width,height,size,type

Ⅲ sql語句 關於去掉重復項的問題

delete from a where col02 in (select col02 from a group by col02 having count(*)>1)

Ⅳ SQL裡面如何刪除重復的記錄

方法1 最簡單的方法,拿出唯一的記錄集,放入中間表。原表清空,再把數據導回來。數據少的話很快。

select distinct UPPER(Stu_ID),*from tableName


方法2 如果這個表特別大,導表的方法速度受不了的話:

  1. 找出所有重復記錄

    1. select * from tableName where Stu_ID_UP in (
      select Stu_ID_UPfrom (select UPPER(Sut_ID) Stu_ID_UP from tableName)
      group by Stu_ID_UP
      having count(Stu_ID_UP) > 1)

  2. 然後人工查看一下這些數據,推測這些重復數據產生的原因,是輸入錯誤、代碼邏輯錯誤、還是業務邏輯錯誤。要是業務原因,那一定要跟業務部門談好解決方案,別刪完出狀況。

  3. 經過第2步的各種確認刪除方法後,開始刪~

保留rowid最小的記錄

delete from tableName a

where (a.Stu_ID) in (

select Stu_ID_UP

from (

select UPPER(Sut_ID) Stu_ID_UP

from tableName)

group by Stu_ID_UP

having count(Stu_ID_UP) > 1)

and rowid not in (select min(rowid)

from (select UPPER(Sut_ID) Stu_ID_UP from tableName)

group by Stu_ID_UP

having count(Stu_ID_UP) > 1)


哎這惡心的排版,這網頁裡面真難調~~~

Ⅳ sql如何去除重復數據

上面的回答可以,不過我覺得還有更簡單的方法:
select aid, count(distinct uid) from 表名 group by aid
這是sqlserver 的寫法。。。

Ⅵ SQL中如何刪除重復數據

select
欄位1,欄位2,欄位3
from
table
group
by
欄位1,欄位2,欄位3
having
count(*)>1
用上邊這句能找出所有重復的數據
欄位1,2,3你替換成你表裡的欄位名,如果有更多欄位的話,你就繼續添加,最後group
by的時候不要忘記了
刪除的時候要建立一個臨時表
create
table
new_table
as
select
欄位1,欄位2,欄位3
from
old_table
group
by
欄位1,欄位2,欄位3;
然後刪除原表數據
truncate
table
old_table;
然後把臨時表數據反插回去
insert
into
new_table
select
*
from
old_table;

Ⅶ SQL查詢去除重復記錄

select distinct(*)
from 表名
where 職業="無業"

上邊distinct 就是去除重復的關鍵字

Ⅷ SQL查詢,如何去除重復的記錄

首先,先說明一個問題。這樣的結果出現,說明系統設計是有問題的。

其次
刪除重復數據,你要提供你是什麼資料庫
不同資料庫會有不同的解決方案。

關鍵字Distinct 去除重復,如下列SQL,去除Test相同的記錄;
1. select distinct Test from Table
2. 如果是要刪除表中存在的重復記錄,那就邏輯處理,如下:
3. select Test from Table group by Test having count(test)>1
4. 先查詢存在重復的數據,後面根據條件刪除

還有一個更簡單的方法可以嘗試一下:
select aid, count(distinct uid) from 表名 group by aid
這是sqlserver 的寫法。

  • 如圖一在數據表中有兩個膀胱沖洗重復的記錄。

Ⅸ 如何用SQL語句去掉重復記錄

COL1 中有重復記錄(COL1,COL2為主鍵),如何刪除

1、有少數重復記錄(在col1,col2上有索引比較好)

DELETE T
WHERE (COL1,COL2) IN
(SELECT COL1,COL2 FROM T GROUP BY COL1,COL2 HAVING COUNT(*) > 1)
AND
ROWID NOT IN
(SELECT MIN(ROWID) FROM T GROUP BY COL1,COL2 HAVING COUNT(*) > 1)

2、大部份記錄有重復記錄

DELETE T WHERE ROWID NOT IN
(SELECT MIN(ROWID) FROM T GROUP BY COL1,COL2)

3、其他寫法

DELETE T WHERE ROWID IN
(SELECT A.ROWID FROM T A,T B
WHERE A.COL1=B.COL1 AND A.COL2 = B.COL2 AND A.ROWID > B.ROWID)

######################################

10. 刪除重復記錄

最高效的刪除重復記錄方法 ( 因為使用了ROWID)

DELETE FROM EMP E

WHERE E.ROWID > (SELECT MIN(X.ROWID)

FROM EMP X

WHERE X.EMP_NO = E.EMP_NO);

11. 用TRUNCATE替代DELETE

當刪除表中的記錄時,在通常情況下, 回滾段(rollback segments ) 用來存放可以被恢復的信息. 如果你沒有COMMIT事務,ORACLE會將數據恢復到刪除之前的狀態(准確地說是

恢復到執行刪除命令之前的狀況)

而當運用TRUNCATE時, 回滾段不再存放任何可被恢復的信息.當命令運行後,數據不能被恢復.因此很少的資源被調用,執行時間也會很短.

(譯者按: TRUNCATE只在刪除全表適用,TRUNCATE是DDL不是DML)

12. 盡量多使用COMMIT

只要有可能,在程序中盡量多使用COMMIT, 這樣程序的性能得到提高,需求也會因為COMMIT所釋放的資源而減少:

COMMIT所釋放的資源:

a. 回滾段上用於恢復數據的信息.

b. 被程序語句獲得的鎖

c. redo log buffer 中的空間

d. ORACLE為管理上述3種資源中的內部花費

Ⅹ sql去除重復數據

測試這樣是可以的
select * from table where a in ( select a from table group by a having count(*)<2)

熱點內容
編程鍵是什麼 發布:2024-09-20 07:52:47 瀏覽:651
學考密碼重置要求的證件是什麼 發布:2024-09-20 07:19:46 瀏覽:477
電腦主伺服器怎麼開機 發布:2024-09-20 07:19:07 瀏覽:728
2022款瑞虎升級哪些配置 發布:2024-09-20 06:59:07 瀏覽:264
資料庫與asp 發布:2024-09-20 06:55:25 瀏覽:727
python解釋編譯 發布:2024-09-20 06:52:57 瀏覽:648
舞蹈豐收腳本 發布:2024-09-20 06:36:26 瀏覽:595
linux進程埠號 發布:2024-09-20 06:36:11 瀏覽:80
派派怎麼改密碼忘了 發布:2024-09-20 06:25:49 瀏覽:780
linux虛擬地址物理地址 發布:2024-09-20 06:23:29 瀏覽:564