반응형
예전 마구잡이로 쿼리를 때렸을 적에는 (지금은 마구잡이가 아니라는 얘기는 아니지만~~~)
간단간단하게 내가 아는 쿼리로만 해결하려고 하는 경향이 있었다.
하지만 이젠 나의 영원한 동반자 구글로 구글링을 해가며 남의 지식을 습득해 사용하고 있는데
Delete 문에서 SubQuery를 통해 Select한 내용을 삭제하고자 한다.
DELETE FROM 테이블1WHERE attach_seq IN(SELECT * FROM(SELECT attach_seqFROM 테이블2 as article,테이블1 as attachWHERE article.article_seq = attach.article_seqand 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 오혜영에게 저작권이 있습니당.
반응형
'DataBase > MySQL, MariaDB' 카테고리의 다른 글
MySQL Storage Engine의 양대산맥! MyISAM vs InnoDB (3) | 2011.03.31 |
---|---|
WHERE 절의 IN 사용법! (0) | 2011.02.08 |
가장 최근 입력된 insert 내용 찾아오기! (1) | 2011.02.02 |
MySQL Hierarchical Data (0) | 2011.01.31 |
답변형 게시판 (OZBoard) (0) | 2011.01.31 |