Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845

Удаление дубликатов из таблицы

28.04.2023, 14:39. Показов 1604. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется таблица без первичного ключа и ограничений UNIQUE. В таблице есть совпадающие строки. Необходимо исключить дубликаты из таблицы.
SQL
1
CREATE TABLE t (a INTEGER, b INTEGER);
Пример данных:
ab
11
22
22
33
33
33
30
Требуемый результат:
ab
11
22
22
33
30
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.04.2023, 14:39
Ответы с готовыми решениями:

Удаление дубликатов postgres
Необходимо для создания уникального констрайнта удалить все дубликаты. Найти повторы можно так SELECT "F_TagName_ID", ...

Удаление дубликатов в колонке
Ребята, привет. Нужна помощь подскажите пожалуйста В таблице T имеется одна колонка NUM типа NUMBER. Таблица заполнена некоторыми...

Удаление дубликатов + ассинхронное удаление из другой таблицы
Есть две таблицы tbl_content : id, title tbl_pics : id, picname 1. Нужно удалить дубликаты "title" из таблицы...

9
55 / 50 / 5
Регистрация: 30.06.2022
Сообщений: 251
28.04.2023, 16:18
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
ROLLBACK;
BEGIN;
CREATE TEMP TABLE tmp_tbl_test(a INT,b INT);
INSERT INTO tmp_tbl_test(a,b)
VALUES
(1,1),
(2,2),
(2,2),
(3,3),
(3,3),
(3,3),
(3,0);
WITH 
    tbl_d(a,b) AS(DELETE FROM tmp_tbl_test RETURNING *),
    tbl_i(a,b) AS(INSERT INTO tmp_tbl_test(a,b) SELECT DISTINCT a,b FROM tbl_d RETURNING *)
SELECT a,b FROM tbl_i;
SELECT * FROM tmp_tbl_test;
DROP TABLE tmp_tbl_test;
COMMIT;
И результат
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
test=# BEGIN;
BEGIN
test=*# CREATE TEMP TABLE tmp_tbl_test(a INT,b INT);
CREATE TABLE
test=*# INSERT INTO tmp_tbl_test(a,b)
test-*# VALUES
test-*# (1,1),
test-*# (2,2),
test-*# (2,2),
test-*# (3,3),
test-*# (3,3),
test-*# (3,3),
test-*# (3,0);
INSERT 0 7
test=*# WITH 
test-*# RECURSIVE tbl_d(a,b) AS(DELETE FROM tmp_tbl_test RETURNING *),
test-*# tbl_i(a,b) AS(INSERT INTO tmp_tbl_test(a,b) SELECT DISTINCT a,b FROM tbl_d RETURNING *)
test-*# SELECT a,b FROM tbl_i;
 a | b 
---+---
 1 | 1
 3 | 3
 3 | 0
 2 | 2
(4 строки)
test=*# SELECT * FROM tmp_tbl_test;
 a | b 
---+---
 1 | 1
 3 | 3
 3 | 0
 2 | 2
(4 строки)
 
test=*# DROP TABLE tmp_tbl_test;
DROP TABLE
test=*# COMMIT;
COMMIT
test=#
1
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845
28.04.2023, 17:14  [ТС]
oktogen, Как можно сделать без создания дополнительной таблицы?
0
55 / 50 / 5
Регистрация: 30.06.2022
Сообщений: 251
28.04.2023, 18:54
Цитата Сообщение от Whitecolor Посмотреть сообщение
oktogen, Как можно сделать без создания дополнительной таблицы?
Студенты ленивые, думать не хотят. Я бы вам двойку влепил :-)
Запрос
SQL
1
2
3
4
WITH 
    tbl_d(a,b) AS(DELETE FROM tmp_tbl_test RETURNING *),
    tbl_i(a,b) AS(INSERT INTO tmp_tbl_test(a,b) SELECT DISTINCT a,b FROM tbl_d RETURNING *)
SELECT a,b FROM tbl_i;
делает это. Одним залпом.
Вместо tmp_tbl_test подставьте свою таблицу и будет вам счастье.
1
14 / 13 / 1
Регистрация: 17.04.2023
Сообщений: 107
05.05.2023, 18:35
oktogen, хорош однако. найти бы еще такого учителя
0
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845
09.06.2023, 14:17  [ТС]
SQL
1
2
3
4
5
6
7
8
9
SELECT* FROM t2del;
SELECT ctid, * FROM t2del;
 
SELECT DISTINCT a, b
FROM t2del;
 
SELECT a, b
FROM t2del;
GROUP BY a, b;
SQL
1
2
3
4
5
6
7
8
9
10
11
WITH del 
AS (
    DELETE
    FROM t2del
    RETURNING a, b 
    )
INSERT INTO t2del
SELECT DISTINCT a, b
FROM del;
 
SELECT* FROM t2del;
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5972 / 3734 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
11.06.2023, 06:46
Всегда делал так:

SQL
1
2
3
4
5
6
7
8
9
10
SELECT
    a,
    b,
    COUNT(*)
FROM
    t 
GROUP BY
    a,
    b
HAVING COUNT(*) > 1;
Так как PK в таблице не указан, то удаление будет чуть сложнее:

SQL
1
2
3
4
5
6
7
8
9
10
11
12
DELETE FROM t
WHERE (a, b) IN (
    SELECT
        a,
        b
    FROM
        t 
    GROUP BY
        a,
        b
    HAVING COUNT(*) > 1
);
Добавлено через 2 минуты
Второй запрос неправильный, не запускайцте

Добавлено через 3 минуты
SQL
1
2
3
4
5
6
DELETE FROM t t1
USING t t2
WHERE
    t1.ctid < t2.ctid
AND t1.a = t2.a
AND t1.b = t2.b;
1
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845
15.06.2023, 10:36  [ТС]
Рыжий Лис, Спасибо, полезно
0
 Аватар для iLinks
799 / 457 / 237
Регистрация: 03.01.2017
Сообщений: 1,337
21.06.2023, 13:27
Цитата Сообщение от Whitecolor Посмотреть сообщение
исключить дубликаты из таблицы
Цитата Сообщение от Whitecolor Посмотреть сообщение
Требуемый результат:
ab
22
22
Интересно
0
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845
21.06.2023, 14:11  [ТС]
iLinks, Ошибся я когда создавал тему
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.06.2023, 14:11
Помогаю со студенческими работами здесь

Удаление дубликатов строк из таблицы
Собственно существует ли какая нибудь команда или универсальный запрос, который подойдет к любой таблице без вникания в ее структуру?

Удаление дубликатов по номеру абонента из таблицы
Есть таблица ABONENT IVR -------------------- -------------------- 77026259611 77029661156 ...

Удаление дубликатов без создания отдельной таблицы
Добрый день. Есть таблица My_Table со столбцами Фамилия, Имя, Отчество, Дата рождения, Телефон, Сцепка. В столбец Сцепка...

Удаление дубликатов
Как удалить из базы дубликаты, т.е. primati key у них отличаются, а отстальный данные совпадают?

Удаление дубликатов
Здравствуйте. В SQL-запросах, особо не силен. Прошу вашей помощи. Есть не маленькая база данных. В ней одна таблица в которой имеется...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru