想刪除表中重復數據,只留下一條,sql怎么寫

PostgreSQL 方法:

DELETE FROM tbl_case_model
WHERE id NOT IN (SELECT MIN(id)  -- 保留id最小的記錄FROM tbl_case_modelGROUP BYcolumn1,   -- 替換為實際重復列名column2,   -- 繼續添加重復列...        -- [所有需要比較的列]
);

因為我這次遇到的情況比較特殊,是表中所有數據都一模一樣,那么使用MIN(id)或MAX(id)的方法確實不可行,因為無法區分重復行。
因此,我們可以這樣操作:

  1. 使用ctid來保留每組重復數據中的一行(例如每組保留最小的ctid)。
  2. 刪除其他重復行。
-- 使用 ctid(系統隱藏列)作為唯一行標識
DELETE FROM tbl_case_model
WHERE ctid NOT IN (SELECT MIN(ctid)  -- 保留每組重復數據中的第一行FROM tbl_case_modelGROUP BY (tbl_case_model.*)  -- 按整行分組
);

ctid:PostgreSQL 的內部隱藏列,表示行的物理位置(類似行地址),絕對唯一

GROUP BY (tbl_case_model.*):按整行所有列分組(這是處理全列重復的關鍵)

MIN(ctid):保留每組重復數據中物理位置最小的行

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/89363.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/89363.shtml
英文地址,請注明出處:http://en.pswp.cn/web/89363.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

微服務中token鑒權設計的4種方式

1. JWT鑒權 「概述」:JWT是一種用于雙方之間安全傳輸信息的簡潔的、URL安全的令牌標準。它基于JSON格式,包含三個部分:頭部(Header)、負載(Payload)和簽名(Signature)。J…

nodejs搭建

1.創建一個空文件夾,在vscode中打開 2.執行命令開啟package文件 npm init -y3.設置根目錄文件app.js 先執行 npm install express 命令安裝 express 模塊 執行 npm install cors 命令安裝 cors 模塊 // app.js const express require(express) const app express…

frp內網穿透(二)

frp內網穿透(二) 前言 前篇內網穿透 上面一文中已描述如何安裝frp進行內網穿透,并配置ssh穿透連接內網服務器,本篇主要介紹如何配置web服務 使用場景 A服務器為公網服務器,B服務器為家庭中內網服務器,且B…

Spring 應用中 Swagger 2.0 遷移 OpenAPI 3.0 詳解:配置、注解與實踐

從 Swagger 2.0 到 OpenAPI 3.0 的升級指南 為什么升級 OpenAPI 3.0提供了更強大的功能、更簡潔的配置和更好的性能,同時保持了與 Swagger 2.0 的基本兼容性。本文將詳細介紹升級的各個步驟,并提供代碼示例。 1. 依賴管理的變化 Swagger 2.0 依賴配置 &l…

用 Flink CEP 打造實時超時預警:從理論到實戰

目錄 1. Flink CEP 是什么?為什么它能讓你的數據“開口說話”? 2. 超時預警的業務場景:從電商到物聯網 3. Flink CEP 超時機制的核心原理 3.1 模式匹配與時間窗口 3.2 超時事件的處理 3.3 事件時間與水位線 3.4 核心組件一覽 4. 實戰案例:電商訂單超時預警 4.1 準備…

Rocky Linux 9 源碼包安裝php7

Rocky Linux 9 源碼包安裝php7大家好!我是星哥。盡管現在 PHP 版本已迭代至 8.x,但有時為了兼容遺留系統或特定應用需求,我們仍需部署特定版本的 PHP。最主要的是之前的項目采用的PHP7.3,未來兼容舊的項目, 今天&#…

uniapp+vue3+鴻蒙系統的開發

前言: uniappvue3鴻蒙系統的開發。 實現效果: 鴻蒙pad端真機測試效果-下面是正常的日志效果 實現步驟: 1、安裝鴻蒙的開發工具,點擊安裝,注意版本不能太舊了 deveco-studio 2、下載下來是個壓縮包,解壓后…

【C++類和對象解密】面向對象編程的核心概念(下)

之前我們了解到構造函數是在對象實例化之時對對象完成初始化工作的一個函數。在我們不寫時,編譯器會自動生成構造函數。構造函數有一些特點,比如,他對內置類型不做處理,對自定義類型的成員會去調用其自身的構造。我們上篇文章還提…

Flutter基礎(前端教程①②-序列幀動畫)

🧠 核心思路總結??徹底繞過 Image組件重建帶來的性能瓶頸??:不再讓 setState重建包含 Image的 Widget 樹(這是開銷大、可能導致閃爍的根源),改為使用底層畫布 (Canvas) 直接繪制預先處理好的圖像幀數據。好的&…

Qt添加dmp文件生成及pdb文件

1.Pdb文件生成 下圖先通過構建生成Pdb文件,然后運行程序,通過提前準備的崩潰按鈕使得程序崩潰,生成“dump文件”的演示。 # #添加dmp文件生成及pdb文件生成DEFINES QT_MESSAGELOGCONTEXT DEFINES QT_DEPRECATED_WARNINGS# # 添加DUMP文件…

opencv、torch、torchvision、tensorflow的區別

一、框架定位與核心差異PyTorch動態計算圖:實時構建計算圖支持Python原生控制流(如循環/條件),調試便捷。學術主導:2025年工業部署份額24%,適合快速原型開發(如無人機自動駕駛、情緒識別&#x…

離散與組合數學 雜記

生成函數 概念 又稱母函數把一個無窮數列 {an}\{a_n\}{an?}(默認從 000 項起)表示成 G(x)∑i≥0aixiG(x)\displaystyle\sum_{i\ge0} a_ix^iG(x)i≥0∑?ai?xi 的函數形式。例如: ai2ia_i2^iai?2i:G(x)∑i≥02ixiG(x)\display…

學習OpenCV---顯示圖片

學習OpenCV—顯示圖片 最近在學習OpenCV入門,于是記錄一下自己的學習過程。 一、配置環境 第一步 從官方網站中下載OpenCV開源庫。官方下載網站 打開官網后,能看到有很多的版本。我個人下載的是4.11.0版本。點擊圖中的下載 下載完成后,解…

第一次接觸自動化監測,需要付費廠家安裝服務嗎?比人工測量主要區別是啥?

人工檢測是依靠目測檢查或借助于便攜式儀器測量得到的信息,但是隨著整個行業的發展,傳統的人工檢測方法已經不能滿足檢測需求,從人工檢測到自動化監測已是必然趨勢。 a. 從檢測方式看 人工檢測需要耗費大量的精力,從擺放檢測工具到…

VMware Workstation Pro 17下載安裝

注冊賬號 進入下載地址:Free Downloads - Support Portal - Broadcom support portal - https://support.broadcom.com/ 會讓注冊賬號,注冊一個就行 在右上角 下載 地址:Free Downloads - Support Portal - Broadcom support portal - ht…

SpringBoot 3.x集成阿里云OSS:文件上傳 斷點續傳 權限控制

SpringBoot 3.x集成阿里云OSS:文件上傳/斷點續傳/權限控制Spring Boot 3.x 集成阿里云 OSS 終極指南一、環境準備與依賴配置1. 添加阿里云 OSS SDK 依賴2. 配置 OSS 連接參數二、基礎文件上傳服務1. OSS 客戶端配置2. 文件上傳服務三、斷點續…

牛客周賽 Round 100

A小紅的雙排列沒什么好說的 直接 1 1 2 2 3 3 4 4……#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<iostream> #include<bits/stdc.h> #define ll long long using namespace std; int n; int main(){ios::sync_with_stdio(false); …

【Dv3Admin】菜單管理集成阿里巴巴自定義矢量圖標庫

圖標選擇是后臺管理系統中高頻功能。相比用 Element UI、Ant Design 等自帶的 icon 集&#xff0c;阿里巴巴 iconfont.cn 支持上傳和管理自定義圖標&#xff0c;并生成矢量字體&#xff0c;便于統一維護和擴展。 本文目標是支持自定義 iconfont 圖標的展示和選擇&#xff0c;并…

NO.7數據結構樹|線索二叉樹|樹森林二叉樹轉化|樹森林遍歷|并查集|二叉排序樹|平衡二叉樹|哈夫曼樹|哈夫曼編碼

線索二叉樹 線索二叉樹的基本概念 為了解決無法直接找到該結點在某種遍歷序列中的前驅和后繼結點的問題&#xff0c; 出現了線索二叉樹。 一個二叉樹通過如下的方法“穿起來” &#xff1a; 所有原本為空的右(孩子)指針改為指向該節點在某種遍歷序列中的后繼&#xff0c; 所有原…

R語言基礎| 基本圖形繪制(條形圖、堆積圖、分組圖、填充條形圖、均值條形圖)

目錄 一、前言 二、條形圖 1. 簡單的條形圖 2.堆積、分組和填充條形圖(柱狀圖) &#xff08;1&#xff09;堆積圖&#xff0c;對Improved進行堆積&#xff0c;注意position“stack” &#xff08;2&#xff09;分組圖&#xff0c;對Improved進行分組&#xff0c;注意posit…