아래 문제의 해답

· 6년 전 · 1304

여러가지 답이 있을 수 있겠지만,  한문장으로는 안되고, 별도로 Column을 추가한후에 지우는 방법입니다.

use simpledb;
ALTER TABLE email_list ADD COLUMN temp SERIAL PRIMARY KEY;
DELETE t1.*
  FROM email_list t1
  LEFT JOIN ( SELECT MIN(Temp) mintemp
                 FROM email_list
                 Group by fname, email ) t2
        on t1.temp = t2.mintemp
    WHERE t2.mintemp is NULL;
ALTER TABLE email_list DROP COLUMN temp;
select * from email_list;

 

 

한문장으로는 아래와 같이 되면 되는데.  CTE 문이 Select에서는 먹히는데,

Delete와 Update에서는 안먹히는 것 같습니다.

Select는 가져오는 것이고 delete와 update는 table을 변경하는 것이라서 안되는 것 같습니다.

 

https://dev.mysql.com/doc/refman/8.0/en/delete.html

 

WITH dup AS 
(
    SELECT fname, email,
    row_number() OVER(PARTITION BY fname, email ORDER BY email) AS NumOfDups
    FROM simpledb.email_list
)
DELETE FROM dup
WHERE NumOfDups > 1;

|
댓글을 작성하시려면 로그인이 필요합니다.

그누5튜닝

+
제목 글쓴이 날짜 조회
6년 전 조회 1,821
6년 전 조회 1,919
6년 전 조회 1,807
6년 전 조회 1,358
6년 전 조회 1,068
6년 전 조회 1,344
6년 전 조회 1,398
6년 전 조회 1,234
6년 전 조회 1,823
6년 전 조회 1,282
6년 전 조회 1,451
6년 전 조회 1,516
6년 전 조회 1,343
6년 전 조회 1,560
6년 전 조회 1,305
6년 전 조회 1,282
6년 전 조회 1,409
6년 전 조회 1,375
6년 전 조회 3,305
6년 전 조회 1,488
6년 전 조회 1,496
6년 전 조회 1,528
6년 전 조회 1,106
6년 전 조회 877
6년 전 조회 981
6년 전 조회 1,081
6년 전 조회 1,357
6년 전 조회 933
6년 전 조회 782
6년 전 조회 1,016