게시판에서 내가 쓴 글과 그 글의 답글도 함께 보여줄 때 사용하는 MySQL Query
제목을 적고 보니 뭔가 많이 허술한 것 같은데.. 일단 아래 이미지를 보면 이해가 빠르지 않을까 싶다.
이미지처럼 내가 쓴 글과 그에 딸린 답글을 보여주는 페이지를 구현하려고 하는데.. 이게 생각 외로 쉽지 않았다.
subquery를 사용하면 될 것이라는 생각까지는 했는데 그 다음에 도대체 어떻게 하면 좋을지 몰라 망설이고 있을 때
문득 원글과 답글을 연결시켜주는 parent 필드가 있다는 것이 생각나서 parent가 같은 것만 뽑아내면 되겠다
까지는 생각을 했는데.. 막상 이걸 query로 작성하려 여기저기 막히기 시작.. ㅋ 처음에는 아래처럼 코드를 작성했다.
where parent = ( select parent from board_table where member = ‘member_id’ order by num asc )
order by num asc
limit 0, 10 “;
즉 board_table 에서 member 의 값이 member_id 인 것의 parent 를 구하고 그것과 일치하는 리스트를 뽑아낸다는
것이다. 이렇게 작성하고 테스트해보니 제대로 작동을 하는 것 같았다. 근데 여기서 한가지 간과한 것이 서브쿼리의
결과값이 하나였기 때문에 에러가 없었다는 것이었다. 에휴~ 테스트로 작성한 글을 두개로 만들어 봤더니 역시나..
아래와 같은 에러 메세지를 보여줬다. 뭐 망설일 것도 없이 바로 구글링… ㅋ
Subquery returns more than 1 row
MySQL 레퍼런스 사이트의 페이지를 보고 쿼리를 수정하니 두 개 일 때도 이상이 없다. 하~ 이렇게 또 하나 해결!!
where parent = ANY ( select parent from board_table where member = ‘member_id’ order by num asc )
order by num asc
limit 0, 10 “;
볼드체의 ANY 만 추가해주면 문제해결.. ㅋ 문제가 그나마 쉽게 해결이 되어서 얼마나 다행인지 모른다. ^_______^
참고 사이트 : http://dev.mysql.com/doc/refman/5.0/en/subquery-errors.html
도움 많이 되었습니다. 감사해요. ^^
부족한 글이 도움이 되었다니 다행입니다. 좋은 하루 되세요.