亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

自關聯去掉組內重復數據

2024-07-21 02:46:08
字體:
來源:轉載
供稿:網友
自關聯去掉組內重復數據

數據庫環境:SQL SERVER 2005

  現有一個表的數據如下,id是主鍵,p1,p2是字符串類型,如果當前行的p1,p2字段的值分別等于其它行

的字段p2,p1的值,則視這2行記錄為一組。比如,id=1和id=5就屬于同一組數據。同一組數據只顯示id最小

的那行記錄,沒有組的數據全部顯示。

實現思路:

  將表進行自關聯左聯,假設表的別名是a,b,根據id進行關聯,對關聯后的結果集進行過濾。如果b.id是空的,則保留,

如果b.id不為空,則只保留a.id比b.id小的記錄。

實現的SQL腳本:

/*1.數據準備*/WITH    x0          AS ( SELECT   1 AS id ,                        'A' AS p1 ,                        'B' AS p2               /*UNION ALL               SELECT   0 AS id ,                        'A' AS p1 ,                        'B' AS p2*/               UNION ALL               SELECT   2 AS id ,                        'C' AS p1 ,                        'D' AS p2               UNION ALL               SELECT   3 AS id ,                        'E' AS p1 ,                        'F' AS p2               UNION ALL               SELECT   4 AS id ,                        'D' AS p1 ,                        'C' AS p2               UNION ALL               SELECT   5 AS id ,                        'B' AS p1 ,                        'A' AS p2               UNION ALL               SELECT   6 AS id ,                        'H' AS p1 ,                        'J' AS p2               UNION ALL               SELECT   7 AS id ,                        'T' AS p1 ,                        'U' AS p2               UNION ALL               SELECT   8 AS id ,                        'J' AS p1 ,                        'H' AS p2               /*UNION ALL               SELECT   9 AS id ,                        'I' AS p1 ,                        'L' AS p2               UNION ALL               SELECT   10 AS id ,                        'J' AS p1 ,                        'K' AS p2*/             ),/*2.去重*/        x1          AS ( SELECT   id ,                        p1 ,                        p2               FROM     ( SELECT    id ,                                    p1 ,                                    p2 ,                                    ROW_NUMBER() OVER ( PARTITION BY p1, p2 ORDER BY id ) AS rn                          FROM      x0                        ) t               WHERE    rn = 1             )    /*3.求值*/    SELECT  a.id ,            a.p1 ,            a.p2    FROM    x1 a            LEFT JOIN x1 b ON b.p1 = a.p2                              AND b.p2 = a.p1    WHERE   b.id IS NULL            OR a.id < b.id
View Code

最終實現的效果如圖:

也有網友提出通過ASCII來實現,他的實現SQL腳本如下:

WITH    c1          AS ( SELECT   1 AS id ,                        'A' AS p1 ,                        'B' AS p2               /*UNION ALL               SELECT   0 AS id ,                        'A' AS p1 ,                        'B' AS p2*/               UNION ALL               SELECT   2 AS id ,                        'C' AS p1 ,                        'D' AS p2               UNION ALL               SELECT   3 AS id ,                        'E' AS p1 ,                        'F' AS p2               UNION ALL               SELECT   4 AS id ,                        'D' AS p1 ,                        'C' AS p2               UNION ALL               SELECT   5 AS id ,                        'B' AS p1 ,                        'A' AS p2               UNION ALL               SELECT   6 AS id ,                        'H' AS p1 ,                        'J' AS p2               UNION ALL               SELECT   7 AS id ,                        'T' AS p1 ,                        'U' AS p2               UNION ALL               SELECT   8 AS id ,                        'J' AS p1 ,                        'H' AS p2               /*UNION ALL               SELECT   9 AS id ,                        'I' AS p1 ,                        'L' AS p2               UNION ALL               SELECT   10 AS id ,                        'J' AS p1 ,                        'K' AS p2*/             ),        c2          AS ( SELECT   MIN(id) AS min_id               FROM     c1               GROUP BY ASCII(p1) + ASCII(p2)             )    SELECT  c1.*    FROM    c1
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美高清激情视频| 久久中文字幕一区| 国产精品一区=区| 亚洲2020天天堂在线观看| 国产aⅴ夜夜欢一区二区三区| 日韩有码在线观看| 中文字幕亚洲欧美一区二区三区| 亚洲高清一区二| 日韩在线观看免费全| 精品国产乱码久久久久久虫虫漫画| 国产精品久久久久久久久免费看| 国模视频一区二区三区| 成人免费视频在线观看超级碰| 狠狠色狠狠色综合日日五| 国产一区二区三区三区在线观看| 久久久久日韩精品久久久男男| 中文字幕亚洲第一| 在线观看国产精品淫| 不卡av在线播放| 国产精自产拍久久久久久蜜| 国产精品精品视频一区二区三区| 欧美精品免费播放| 岛国视频午夜一区免费在线观看| 欧美肥老妇视频| 成人免费看吃奶视频网站| 久久国产精品亚洲| 国产欧美日韩精品丝袜高跟鞋| 97精品国产97久久久久久免费| 亚洲欧美日本伦理| 91国偷自产一区二区三区的观看方式| 91国产美女在线观看| 欧美性xxxxxx| 日韩免费观看高清| 一本久久综合亚洲鲁鲁| 91精品久久久久久综合乱菊| 97婷婷大伊香蕉精品视频| 亚洲国产精品久久91精品| 亚洲一级黄色av| 日韩欧美一区二区在线| 日本一本a高清免费不卡| 久久电影一区二区| 亚洲人成电影网站色www| 亚洲成avwww人| 久久成人精品一区二区三区| 欧美日韩中文字幕日韩欧美| 在线播放日韩av| 欧美国产精品va在线观看| 欧美亚洲午夜视频在线观看| 欧美二区在线播放| 亚洲高清久久网| 亚洲欧洲日韩国产| 久久亚洲欧美日韩精品专区| 欧美性猛交xxxx黑人| 亚洲aaa激情| 日韩中文在线中文网三级| 欧美日韩在线视频首页| 国产69精品久久久久9999| 久久精品一偷一偷国产| 国产精品久久久久9999| 在线日韩精品视频| 麻豆一区二区在线观看| 精品久久中文字幕久久av| 国精产品一区一区三区有限在线| 精品成人国产在线观看男人呻吟| 国产精品三级美女白浆呻吟| 日韩美女写真福利在线观看| 久久九九全国免费精品观看| 久久免费高清视频| 26uuu亚洲国产精品| 亚洲自拍高清视频网站| 日韩欧美精品网站| 欧美在线激情网| 欧美日韩视频在线| 欧美性极品少妇精品网站| 91久久精品美女| 国产999在线| 久久精品精品电影网| 欧美怡红院视频一区二区三区| 中文字幕亚洲二区| 亚洲精品自在久久| 国产精品极品美女在线观看免费| 国产精品男人爽免费视频1| 自拍视频国产精品| 亚洲无限乱码一二三四麻| 欧美激情va永久在线播放| 91视频国产高清| 2019中文字幕全在线观看| 91精品视频专区| 日韩中文字幕第一页| 亚洲欧美制服第一页| 精品自拍视频在线观看| 成人午夜在线观看| 国内外成人免费激情在线视频| 在线观看日韩欧美| 91精品视频免费| 国产91ⅴ在线精品免费观看| 久久精品一偷一偷国产| 亚洲一区亚洲二区亚洲三区| 欧美性色视频在线| 尤物tv国产一区| 日本一区二区在线播放| 亚洲一区二区久久久久久久| 国产成人精品在线观看| 亚洲精品国产综合区久久久久久久| 久久久久久久91| 国内精品视频在线| 日韩av中文字幕在线免费观看| 国产精品久久久久久久7电影| 国产精品久在线观看| 久久久精品网站| 在线性视频日韩欧美| 亚洲新声在线观看| 国产欧美日韩精品丝袜高跟鞋| 国产精品www| 国产精品久久久久久久午夜| 2019日本中文字幕| 亚洲美女av在线| 色婷婷久久av| 亚洲国产精品电影| 中文字幕国产亚洲2019| 91av视频导航| 中文字幕av一区中文字幕天堂| 国产成人精品在线视频| 欧美激情一区二区三区久久久| 国产性猛交xxxx免费看久久| 91日本在线视频| 在线精品91av| 国产自摸综合网| 九九视频直播综合网| 亚洲综合在线做性| 日韩中文字幕不卡视频| 九九热最新视频//这里只有精品| 欧美日韩国产丝袜另类| 久久久999精品视频| 欧美一区二区三区免费视| 欧美日本在线视频中文字字幕| 欧美高清性猛交| 中文字幕亚洲欧美日韩在线不卡| 亚洲精品视频在线观看视频| 亚洲女人天堂色在线7777| 亚洲欧美日韩综合| 欧美激情第99页| 久久久久久亚洲精品中文字幕| 亚洲欧美中文字幕在线一区| 亚洲天堂av在线免费观看| 亚洲欧美国产精品久久久久久久| 国产成人精品av| 色综合久久久久久中文网| 成人高清视频观看www| 2019中文在线观看| 丝袜美腿精品国产二区| 国产一区二区三区在线播放免费观看| 亚洲理论在线a中文字幕| 中文字幕在线看视频国产欧美| 欧美高清视频在线观看| 国产精品日韩电影| 久久久久久中文字幕| 国产91在线播放精品91| 国产午夜精品免费一区二区三区| 在线精品高清中文字幕| 8050国产精品久久久久久| 国产精品电影在线观看| 美日韩在线视频| 亚洲男人天堂九九视频|