본문 바로가기
DataBase/MySQL, MariaDB

Select와 동시에 Delete 하기.

by ojava 2011. 2. 8.
반응형

예전 마구잡이로 쿼리를 때렸을 적에는 (지금은 마구잡이가 아니라는 얘기는 아니지만~~~)
간단간단하게 내가 아는 쿼리로만 해결하려고 하는 경향이 있었다.
하지만 이젠 나의 영원한 동반자 구글로 구글링을 해가며 남의 지식을 습득해 사용하고 있는데
Delete 문에서 SubQuery를 통해 Select한 내용을 삭제하고자 한다.



    DELETE FROM 테이블1 
       WHERE attach_seq IN 
       (SELECT * FROM 
              (SELECT attach_seq 
                FROM 테이블2 as article, 
                     테이블1 as attach 
               WHERE article.article_seq = attach.article_seq 
                and module_seq = 23
              ) as result 
       )




게시물과 첨부파일 간의 관계에 대해서 
간단한 쿼리죠~ 하지만 이 문제를 해결하기 위해서 끙끙거렸는데.. 바로
you can't specify target table for update in from clause 라는 오류메시지를 만났기 때문이지영.


여기서 의문점이 생기죠!!! 왜 SubQuery를 또 다시 한 번 더 감싸줄까용????

그 이유는~~~ insert가 아닌 다른 나머지 기본 명령인 update, delete를 위해서 SubQuery를 수행할 때는
SubQuery 내의 From절의 테이블과 바꾸기를 원하는 target인 테이블을 위해서 같은 테이블을 사용할 수 
없기 때문입니당.

현재 위의 쿼리에서 감싸준 SubQuery를 제거하게 되면 테이블1 이라는 테이블이 중복되어 사용되므로 
위와 같은 오류메시지를 만날 수 있습니다 ㅠ_ㅠ.

이때 빼먹으시면 안 될 것으로는 안쪽의 SubQuery에는 alias를 주셔야 한다는 점!!!


여기서 하나 더~
WHERE attach_seq IN 은 무엇일까요?

WHERE 절에서 IN을 사용하는 것은, 이것과 같은 것을 찾아라~ 라는 뜻인데요.
위의 쿼리에서는 attach_seq 라는 값이 SubQuery 안에 있는 내용인 것을 찾아라~ 라는 뜻이 되겠지영.
추가적인 사용 방안에 대해서는 다음 글에 포스팅 하겠솨여~




2011.02 오혜영에게 저작권이 있습니당.

반응형