Intereting Posts
Устанавливать переменную внутри CTE Простая программа Windows Service Vs Операция интеллектуального анализа данных с использованием SQL Query (Fuzzy Apriori Algorithm) – Как я могу ее кодировать с помощью SQL? Как запросить нулевые значения в поле типа json postgresql? Как вы можете вызвать пользовательские функции базы данных с помощью Hibernate? Удалить столбец из таблицы SQLite Как создать вложенный SELECT COUNT с псевдонимом в Postgres SQL: проверить вставку успешно (в задаче получить 8 отдельных случайных строк из таблицы с двумя столбцами) SQL выберите доступные комнаты по дате cheking SQL Аргумент LIMIT не должен содержать переменных Что делает (+) в Oracle SQL? Функция Python SQL, запрос к групповым датам по протоколам Как подсчитать количество символов, появляющихся в столбце SQL? Нужна некоторая серьёзная помощь с проблемой самостоятельного присоединения Таблица Pivot SQL (строки в столбцы)

Найти повторяющиеся записи в столбце

Я пишу этот запрос, чтобы найти дубликаты CTN Records в таблице1. Поэтому я думаю, что если CTN_NO появляется более чем в два раза или выше, я хочу, чтобы это было показано в моем выводе SELECT *.

Я пробовал следующую логику подзапроса, но мне нужны тяги

SELECT * table1 WHERE S_IND='Y' and CTN_NO = (select CTN_NO from table1 where S_IND='Y' and count(CTN_NO) < 2); order by 2 

С помощью:

  SELECT t.ctn_no FROM YOUR_TABLE t GROUP BY t.ctn_no HAVING COUNT(t.ctn_no) > 1 

… покажет вам значения ctn_no которые имеют дубликаты в вашей таблице. Добавление критериев в WHERE позволит вам дополнительно настроить, какие дубликаты есть:

  SELECT t.ctn_no FROM YOUR_TABLE t WHERE t.s_ind = 'Y' GROUP BY t.ctn_no HAVING COUNT(t.ctn_no) > 1 

Если вы хотите увидеть другие значения столбца, связанные с дубликатом, вы захотите использовать самостоятельное соединение:

 SELECT x.* FROM YOUR_TABLE x JOIN (SELECT t.ctn_no FROM YOUR_TABLE t GROUP BY t.ctn_no HAVING COUNT(t.ctn_no) > 1) y ON y.ctn_no = x.ctn_no 

Попробуйте этот запрос .. Он использует аналитическую функцию SUM:

 SELECT * FROM ( SELECT SUM(1) OVER(PARTITION BY ctn_no) cnt, A.* FROM table1 a WHERE s_ind ='Y' ) WHERE cnt > 2 

Не уверен, почему вы идентифицируете запись как дубликат, если ctn_no повторяет более 2 раз. Я повторяю, что это повторяется не один раз, это дубликат. В этом случае измените las-часть запроса на WHERE cnt > 1