하나의 테이블에서 원글의 답글과 댓글의 답글을 모두 해결하는 방식을 찾고자 합니다.
테이블의 구조를 다음과 같이 구성합니다.
컬럼명 |
종류 | 설명 |
wr_id |
int | 고유아이디 |
wr_parent |
int | 부모아이디 |
wr_comment |
int | 0이면 원글, 아니면 댓글 |
wr_reply | varchar(10) | 0~9 그리고 a~z 36진수 사용 0은 제외 깊이는 10개 까지로 한정함 |
wr_comment_cnt | int | 원글에서 댓글의 수를 저장 |
wr_subject | varchar(255) | 제목 |
글이 다음과 같이 저장되어 있다고 했을때
SQL 질의: SELECT * FROM `a_write` LIMIT 0, 25 ;
행 : 14
| wr_id | wr_parent | wr_comment | wr_reply | wr_comment_cnt | wr_subject |
|---|---|---|---|---|---|
| 1 | 1 | 0 | 5 | 원글1 | |
| 2 | 1 | 0 | 1 | 0 | 원글1-1 |
| 3 | 1 | 0 | 2 | 0 | 원글1-2 |
| 4 | 1 | 0 | 11 | 0 | 원글1-1-1 |
| 5 | 2 | 0 | 0 | 원글2 | |
| 6 | 2 | 0 | 1 | 0 | 원글2-1 |
| 7 | 1 | 1 | 1 | 댓글1 | |
| 8 | 1 | 2 | 2 | 댓글2 | |
| 9 | 1 | 3 | 0 | 댓글3 | |
| 10 | 1 | 2 | 1 | 0 | 댓글2-1 |
| 11 | 1 | 2 | 11 | 0 | 댓글2-1-1 |
| 12 | 1 | 1 | 1 | 0 | 댓글1-1 |
| 13 | 2 | 0 | 2 | 0 | 원글2-2 |
| 14 | 1 | 0 | 21 | 0 | 원글1-2-1 |
원글을 표시할때는 이 쿼리를 실행합니다.
답변의 깊이(depth)는 wr_reply 의 갯수로 처리할수 있습니다.
SQL 질의: SELECT * FROM `a_write` where wr_comment = 0 order by wr_parent desc, wr_reply LIMIT 0, 25 ;
행 : 8
| wr_id | wr_parent | wr_comment | wr_reply | wr_comment_cnt | wr_subject |
|---|---|---|---|---|---|
| 5 | 2 | 0 | 0 | 원글2 | |
| 6 | 2 | 0 | 1 | 0 | 원글2-1 |
| 13 | 2 | 0 | 2 | 0 | 원글2-2 |
| 1 | 1 | 0 | 5 | 원글1 | |
| 2 | 1 | 0 | 1 | 0 | 원글1-1 |
| 4 | 1 | 0 | 11 | 0 | 원글1-1-1 |
| 3 | 1 | 0 | 2 | 0 | 원글1-2 |
| 14 | 1 | 0 | 21 | 0 | 원글1-2-1 |
1번 게시물 만을 모아보는 경우에는 이렇게 쉽게 처리할수 있습니다.
SQL 질의: SELECT * FROM `a_write` where wr_parent=1 and wr_comment = 0 order by wr_parent desc, wr_reply LIMIT 0, 25 ;
행 : 5
| wr_id | wr_parent | wr_comment | wr_reply | wr_comment_cnt | wr_subject |
|---|---|---|---|---|---|
| 1 | 1 | 0 | 5 | 원글1 | |
| 2 | 1 | 0 | 1 | 0 | 원글1-1 |
| 4 | 1 | 0 | 11 | 0 | 원글1-1-1 |
| 3 | 1 | 0 | 2 | 0 | 원글1-2 |
| 14 | 1 | 0 | 21 | 0 | 원글1-2-1 |
1번의 코멘트 만 노출하는 경우에는 이렇게 처리합니다.
SQL 질의: SELECT * FROM `a_write` where wr_parent = 1 and wr_comment > 0 order by wr_comment, wr_reply LIMIT 0, 25 ;
행 : 6
| wr_id | wr_parent | wr_comment | wr_reply | wr_comment_cnt | wr_subject |
|---|---|---|---|---|---|
| 7 | 1 | 1 | 1 | 댓글1 | |
| 12 | 1 | 1 | 1 | 0 | 댓글1-1 |
| 8 | 1 | 2 | 2 | 댓글2 | |
| 10 | 1 | 2 | 1 | 0 | 댓글2-1 |
| 11 | 1 | 2 | 11 | 0 | 댓글2-1-1 |
| 9 | 1 | 3 | 0 | 댓글3 |
위와 같이 몇개 안되는 샘플 데이트로 살펴 보았지만 충분히 원글의 답글과 댓글의 답글을 표현할수 있는것을 확인하였습니다.
댓글 1개
이것을 간과했네요.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 130 | 20년 전 | 4021 | ||
| 129 | 20년 전 | 2959 | ||
| 128 | 20년 전 | 3697 | ||
| 127 | 20년 전 | 3534 | ||
| 126 | 20년 전 | 3788 | ||
| 125 | 20년 전 | 8607 | ||
| 124 | 20년 전 | 2612 | ||
| 123 | 20년 전 | 3768 | ||
| 122 | 20년 전 | 3225 | ||
| 121 | 20년 전 | 2627 | ||
| 120 | 20년 전 | 2690 | ||
| 119 | 20년 전 | 2597 | ||
| 118 | 20년 전 | 2872 | ||
| 117 |
|
20년 전 | 3071 | |
| 116 | 20년 전 | 5336 | ||
| 115 | 21년 전 | 3938 | ||
| 114 | 21년 전 | 4987 | ||
| 113 | 21년 전 | 6229 | ||
| 112 | 21년 전 | 7337 | ||
| 111 | 21년 전 | 18449 | ||
| 110 | 21년 전 | 6891 | ||
| 109 | 21년 전 | 2898 | ||
| 108 | 21년 전 | 4153 | ||
| 107 |
prosper
|
21년 전 | 2514 | |
| 106 |
prosper
|
21년 전 | 4336 | |
| 105 |
아우겐나이스
|
21년 전 | 2932 | |
| 104 | 21년 전 | 2278 | ||
| 103 | 21년 전 | 2490 | ||
| 102 | 21년 전 | 2276 | ||
| 101 | 21년 전 | 2593 | ||
| 100 | 21년 전 | 1765 | ||
| 99 | 21년 전 | 1584 | ||
| 98 | 21년 전 | 1635 | ||
| 97 | 21년 전 | 2149 | ||
| 96 | 21년 전 | 1896 | ||
| 95 | 21년 전 | 2395 | ||
| 94 | 21년 전 | 3583 | ||
| 93 | 21년 전 | 1577 | ||
| 92 | 21년 전 | 1773 | ||
| 91 | 21년 전 | 3194 | ||
| 90 | 21년 전 | 2356 | ||
| 89 | 21년 전 | 3192 | ||
| 88 | 21년 전 | 2878 | ||
| 87 | 21년 전 | 3307 | ||
| 86 | 21년 전 | 5154 | ||
| 85 | 21년 전 | 2539 | ||
| 84 | 21년 전 | 4840 | ||
| 83 | 21년 전 | 2518 | ||
| 82 | 21년 전 | 3131 | ||
| 81 | 21년 전 | 7647 | ||
| 80 | 21년 전 | 3845 | ||
| 79 | 21년 전 | 3228 | ||
| 78 | 21년 전 | 4709 | ||
| 77 | 21년 전 | 2920 | ||
| 76 | 21년 전 | 6233 | ||
| 75 | 21년 전 | 4486 | ||
| 74 | 21년 전 | 5801 | ||
| 73 | 21년 전 | 3639 | ||
| 72 | 21년 전 | 5983 | ||
| 71 | 21년 전 | 3135 | ||
| 70 | 21년 전 | 2863 | ||
| 69 | 21년 전 | 2653 | ||
| 68 | 21년 전 | 2462 | ||
| 67 | 21년 전 | 2671 | ||
| 66 | 21년 전 | 2693 | ||
| 65 | 21년 전 | 3800 | ||
| 64 | 21년 전 | 2843 | ||
| 63 | 21년 전 | 2470 | ||
| 62 | 21년 전 | 2283 | ||
| 61 | 21년 전 | 3100 | ||
| 60 | 21년 전 | 3153 | ||
| 59 | 21년 전 | 2532 | ||
| 58 | 21년 전 | 2605 | ||
| 57 | 21년 전 | 2989 | ||
| 56 | 21년 전 | 2348 | ||
| 55 | 21년 전 | 2778 | ||
| 54 | 21년 전 | 2149 | ||
| 53 | 21년 전 | 2378 | ||
| 52 | 21년 전 | 2719 | ||
| 51 |
prosper
|
21년 전 | 2372 | |
| 50 |
prosper
|
21년 전 | 2185 | |
| 49 | 21년 전 | 2202 | ||
| 48 | 21년 전 | 2362 | ||
| 47 | 21년 전 | 1955 | ||
| 46 | 21년 전 | 1941 | ||
| 45 | 21년 전 | 2148 | ||
| 44 | 21년 전 | 2377 | ||
| 43 | 21년 전 | 4592 | ||
| 42 |
prosper
|
21년 전 | 2727 | |
| 41 |
prosper
|
21년 전 | 2128 | |
| 40 | 21년 전 | 2191 | ||
| 39 | 21년 전 | 2160 | ||
| 38 | 21년 전 | 2437 | ||
| 37 | 21년 전 | 2580 | ||
| 36 | 21년 전 | 1794 | ||
| 35 | 21년 전 | 4091 | ||
| 34 | 21년 전 | 3866 | ||
| 33 | 21년 전 | 3009 | ||
| 32 |
prosper
|
21년 전 | 2923 | |
| 31 | 21년 전 | 5304 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기