아래 문제의 해답 > 그누5튜닝

그누5튜닝

아래 문제의 해답 정보

아래 문제의 해답

본문

여러가지 답이 있을 수 있겠지만,  한문장으로는 안되고, 별도로 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;

공감
0

댓글 0개

전체 57 |RSS
그누5튜닝 내용 검색

회원로그인

진행중 포인트경매

  1. 참여4 회 시작24.04.25 20:23 종료24.05.02 20:23
(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT