Как я нахожу дублирующиеся значения в таблице в Oracle?

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

Например, ниже - класс ученика, который будет использовать его в нашем коде.

public class Student {

    private int id;

    public int getId() {
        return this.id;
    }

    public setId(int newId) {
        this.id = newId;
    }
}

Приведенный ниже код дает вам исключение с нулевым указателем.

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}

Поскольку вы используете Obj_Student, но вы забыли инициализировать его, как в правильном коде, показанном ниже:

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student = new Student();
            obj_Student.setId(12);
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}
265
задан Bill the Lizard 9 July 2012 в 00:06
поделиться

6 ответов

SELECT column_name, COUNT(column_name)
FROM table_name
GROUP BY column_name
HAVING COUNT(column_name) > 1;
587
ответ дан Chivorn 23 November 2019 в 02:26
поделиться

Иначе:

SELECT *
FROM TABLE A
WHERE EXISTS (
  SELECT 1 FROM TABLE
  WHERE COLUMN_NAME = A.COLUMN_NAME
  AND ROWID < A.ROWID
)

Хорошо работает (достаточно быстрый), когда существует индекс на column_name. И это - лучший способ удалить или обновить дублирующиеся строки.

57
ответ дан Bill the Lizard 23 November 2019 в 02:26
поделиться

Самый простой я могу думать:

select job_number, count(*)
from jobs
group by job_number
having count(*) > 1;
32
ответ дан JosephStyons 23 November 2019 в 02:26
поделиться

У Вас не должно даже быть количества в возвращенных столбцах, если Вы не должны знать фактическое количество дубликатов. например,

SELECT column_name
FROM table
GROUP BY column_name
HAVING COUNT(*) > 1
17
ответ дан Evan 23 November 2019 в 02:26
поделиться

Как насчет:

SELECT <column>, count(*)
FROM <table>
GROUP BY <column> HAVING COUNT(*) > 1;

Для ответа на пример выше это было бы похоже:

SELECT job_number, count(*)
FROM jobs
GROUP BY job_number HAVING COUNT(*) > 1;
7
ответ дан Andrew 23 November 2019 в 02:26
поделиться

Выполнение

select count(j1.job_number), j1.job_number, j1.id, j2.id
from   jobs j1 join jobs j2 on (j1.job_numer = j2.job_number)
where  j1.id != j2.id
group by j1.job_number

даст Вам идентификаторы дублированных строк.

4
ответ дан agnul 23 November 2019 в 02:26
поделиться
Другие вопросы по тегам:

Похожие вопросы: