아래 문제의 해답

· 6년 전 · 1229

여러가지 답이 있을 수 있겠지만,  한문장으로는 안되고, 별도로 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,765
6년 전 조회 1,843
6년 전 조회 1,752
6년 전 조회 1,304
6년 전 조회 1,020
6년 전 조회 1,295
6년 전 조회 1,346
6년 전 조회 1,167
6년 전 조회 1,758
6년 전 조회 1,230
6년 전 조회 1,393
6년 전 조회 1,447
6년 전 조회 1,271
6년 전 조회 1,483
6년 전 조회 1,230
6년 전 조회 1,199
6년 전 조회 1,340
6년 전 조회 1,307
6년 전 조회 3,231
6년 전 조회 1,419
6년 전 조회 1,420
6년 전 조회 1,441
6년 전 조회 1,041
6년 전 조회 816
6년 전 조회 932
6년 전 조회 1,030
6년 전 조회 1,296
6년 전 조회 844
6년 전 조회 711
6년 전 조회 955