valore - update sql sintassi




Ricerca di valori duplicati in una tabella SQL (17)

Come possiamo contare i valori duplicati ?? o si ripete 2 volte o più di 2. contali, non in gruppo.

semplice come

select COUNT(distinct col_01) from Table_01

È facile trovare duplicates con un campo:

SELECT name, COUNT(email) 
FROM users
GROUP BY email
HAVING COUNT(email) > 1

Quindi se abbiamo un tavolo

ID   NAME   EMAIL
1    John   [email protected]
2    Sam    [email protected]
3    Tom    [email protected]
4    Bob    [email protected]
5    Tom    [email protected]

Questa query ci darà John, Sam, Tom, Tom perché hanno tutti la stessa email .

Tuttavia, quello che voglio è ottenere duplicati con la stessa email e il name .

Cioè, voglio ottenere "Tom", "Tom".

Il motivo per cui ho bisogno di questo: ho commesso un errore e ho permesso di inserire name duplicati e valori email . Ora ho bisogno di rimuovere / modificare i duplicati, quindi ho bisogno di trovarli prima.


Nel caso si lavori con Oracle, in questo modo sarebbe preferibile:

create table my_users(id number, name varchar2(100), email varchar2(100));

insert into my_users values (1, 'John', '[email protected]');
insert into my_users values (2, 'Sam', '[email protected]');
insert into my_users values (3, 'Tom', '[email protected]');
insert into my_users values (4, 'Bob', '[email protected]');
insert into my_users values (5, 'Tom', '[email protected]');

commit;

select *
  from my_users
 where rowid not in (select min(rowid) from my_users group by name, email);

Prova quanto segue:

SELECT * FROM
(
    SELECT Id, Name, Age, Comments, Row_Number() OVER(PARTITION BY Name, Age ORDER By Name)
        AS Rank 
        FROM Customers
) AS B WHERE Rank>1

Prova questo:

SELECT name, email
FROM users
GROUP BY name, email
HAVING ( COUNT(*) > 1 )

Questo dovrebbe funzionare, magari provarlo.

  Select * from Users a
            where EXISTS (Select * from Users b 
                where (     a.name = b.name 
                        OR  a.email = b.email)
                     and a.ID != b.id)

Soprattutto nel tuo caso Se cerchi duplicati con qualche tipo di prefisso o cambiamento generale come ad esempio il nuovo dominio nella posta. allora puoi usare replace () su queste colonne


Questo seleziona / elimina tutti i record duplicati ad eccezione di un record di ciascun gruppo di duplicati. Quindi, l'eliminazione lascia tutti i record univoci + un record per ogni gruppo di duplicati.

Seleziona i duplicati:

SELECT *
FROM table
WHERE
    id NOT IN (
        SELECT MIN(id)
        FROM table
        GROUP BY column1, column2
);

Elimina i duplicati:

DELETE FROM table
WHERE
    id NOT IN (
        SELECT MIN(id)
        FROM table
        GROUP BY column1, column2
);

Essere consapevoli di una maggiore quantità di record, può causare problemi di prestazioni.


Se vuoi eliminare i duplicati, ecco un modo molto più semplice per farlo rispetto al dover trovare le righe pari / dispari in una sottoselezione tripla:

SELECT id, name, email 
FROM users u, users u2
WHERE u.name = u2.name AND u.email = u2.email AND u.id > u2.id

E così da eliminare:

DELETE FROM users
WHERE id IN (
    SELECT id/*, name, email*/
    FROM users u, users u2
    WHERE u.name = u2.name AND u.email = u2.email AND u.id > u2.id
)

Molto più facile da leggere e capire IMHO

Nota: l'unico problema è che devi eseguire la richiesta fino a quando non viene eliminata alcuna riga, poiché ogni volta si elimina solo 1 di ciascun duplicato


Se vuoi vedere se ci sono delle righe duplicate nella tua tabella, ho usato sotto Query:

create table my_table(id int, name varchar(100), email varchar(100));

insert into my_table values (1, 'shekh', '[email protected]');
insert into my_table values (1, 'shekh', '[email protected]');
insert into my_table values (2, 'Aman', '[email protected]');
insert into my_table values (3, 'Tom', '[email protected]');
insert into my_table values (4, 'Raj', '[email protected]');


Select COUNT(1) As Total_Rows from my_table 
Select Count(1) As Distinct_Rows from ( Select Distinct * from my_table) abc 

prova questo codice

WITH CTE AS

( SELECT Id, Name, Age, Comments, RN = ROW_NUMBER()OVER(PARTITION BY Name,Age ORDER BY ccn)
FROM ccnmaster )
select * from CTE 

prova questo:

declare @YourTable table (id int, name varchar(10), email varchar(50))

INSERT @YourTable VALUES (1,'John','John-email')
INSERT @YourTable VALUES (2,'John','John-email')
INSERT @YourTable VALUES (3,'fred','John-email')
INSERT @YourTable VALUES (4,'fred','fred-email')
INSERT @YourTable VALUES (5,'sam','sam-email')
INSERT @YourTable VALUES (6,'sam','sam-email')

SELECT
    name,email, COUNT(*) AS CountOf
    FROM @YourTable
    GROUP BY name,email
    HAVING COUNT(*)>1

PRODUZIONE:

name       email       CountOf
---------- ----------- -----------
John       John-email  2
sam        sam-email   2

(2 row(s) affected)

se vuoi che gli ID dei duplicati usino questo:

SELECT
    y.id,y.name,y.email
    FROM @YourTable y
        INNER JOIN (SELECT
                        name,email, COUNT(*) AS CountOf
                        FROM @YourTable
                        GROUP BY name,email
                        HAVING COUNT(*)>1
                    ) dt ON y.name=dt.name AND y.email=dt.email

PRODUZIONE:

id          name       email
----------- ---------- ------------
1           John       John-email
2           John       John-email
5           sam        sam-email
6           sam        sam-email

(4 row(s) affected)

per eliminare i duplicati prova:

DELETE d
    FROM @YourTable d
        INNER JOIN (SELECT
                        y.id,y.name,y.email,ROW_NUMBER() OVER(PARTITION BY y.name,y.email ORDER BY y.name,y.email,y.id) AS RowRank
                        FROM @YourTable y
                            INNER JOIN (SELECT
                                            name,email, COUNT(*) AS CountOf
                                            FROM @YourTable
                                            GROUP BY name,email
                                            HAVING COUNT(*)>1
                                        ) dt ON y.name=dt.name AND y.email=dt.email
                   ) dt2 ON d.id=dt2.id
        WHERE dt2.RowRank!=1
SELECT * FROM @YourTable

PRODUZIONE:

id          name       email
----------- ---------- --------------
1           John       John-email
3           fred       John-email
4           fred       fred-email
5           sam        sam-email

(4 row(s) affected)

SELECT id, COUNT(id) FROM table1 GROUP BY id HAVING COUNT(id)>1;

Penso che funzionerà correttamente per cercare valori ripetuti in una particolare colonna.


Come ottenere il record duplicato nella tabella

SELECT COUNT (Codice), Codice FROM Dipendenti DOVE Stato = 1 GROUP BY Codice HAVING COUNT (Codice)> 1


 SELECT name, email 
    FROM users
    WHERE email in
    (SELECT email FROM users
    GROUP BY email 
    HAVING COUNT(*)>1)

 select emp.ename, emp.empno, dept.loc 
          from emp
 inner join dept 
          on dept.deptno=emp.deptno
 inner join
    (select ename, count(*) from
    emp
    group by ename, deptno
    having count(*) > 1)
 t on emp.ename=t.ename order by emp.ename
/

SELECT
  FirstName, LastName, MobileNo, COUNT(1) as CNT 
FROM        
  CUSTOMER
GROUP BY
  FirstName, LastName, MobileNo 
HAVING
  COUNT(1) > 1;

SELECT * FROM users u where rowid = (select max(rowid) from users u1 where
u.email=u1.email);

select name, email
, case 
when ROW_NUMBER () over (partition by name, email order by name) > 1 then 'Yes'
else 'No'
end "duplicated ?"
from users




duplicates