하나의 테이블에서 원글의 답글과 댓글의 답글을 모두 해결하는 방식을 찾고자 합니다.
테이블의 구조를 다음과 같이 구성합니다.
컬럼명 |
종류 | 설명 |
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개
이것을 간과했네요.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 8030 | 9년 전 | 393 | ||
| 8029 | 9년 전 | 322 | ||
| 8028 | 9년 전 | 282 | ||
| 8027 | 9년 전 | 290 | ||
| 8026 | 9년 전 | 358 | ||
| 8025 | 9년 전 | 400 | ||
| 8024 | 9년 전 | 362 | ||
| 8023 | 9년 전 | 408 | ||
| 8022 | 9년 전 | 328 | ||
| 8021 | 9년 전 | 342 | ||
| 8020 | 9년 전 | 337 | ||
| 8019 | 9년 전 | 355 | ||
| 8018 | 9년 전 | 456 | ||
| 8017 | 9년 전 | 545 | ||
| 8016 | 9년 전 | 356 | ||
| 8015 | 9년 전 | 403 | ||
| 8014 | 9년 전 | 337 | ||
| 8013 | 9년 전 | 255 | ||
| 8012 | 9년 전 | 260 | ||
| 8011 | 9년 전 | 459 | ||
| 8010 | 9년 전 | 312 | ||
| 8009 | 9년 전 | 323 | ||
| 8008 | 9년 전 | 300 | ||
| 8007 | 9년 전 | 443 | ||
| 8006 | 9년 전 | 482 | ||
| 8005 |
|
9년 전 | 980 | |
| 8004 | 9년 전 | 369 | ||
| 8003 | 9년 전 | 436 | ||
| 8002 | 9년 전 | 331 | ||
| 8001 |
|
9년 전 | 676 | |
| 8000 | 9년 전 | 435 | ||
| 7999 | 9년 전 | 390 | ||
| 7998 | 9년 전 | 448 | ||
| 7997 | 9년 전 | 322 | ||
| 7996 | 9년 전 | 551 | ||
| 7995 | 9년 전 | 484 | ||
| 7994 | 9년 전 | 359 | ||
| 7993 | 9년 전 | 422 | ||
| 7992 | 9년 전 | 528 | ||
| 7991 | 9년 전 | 268 | ||
| 7990 | 9년 전 | 305 | ||
| 7989 | 9년 전 | 318 | ||
| 7988 | 9년 전 | 745 | ||
| 7987 | 9년 전 | 448 | ||
| 7986 | 9년 전 | 447 | ||
| 7985 | 9년 전 | 521 | ||
| 7984 | 9년 전 | 443 | ||
| 7983 | 9년 전 | 685 | ||
| 7982 | 9년 전 | 547 | ||
| 7981 | 9년 전 | 496 | ||
| 7980 | 9년 전 | 519 | ||
| 7979 | 9년 전 | 505 | ||
| 7978 | 9년 전 | 475 | ||
| 7977 | 9년 전 | 413 | ||
| 7976 | 9년 전 | 869 | ||
| 7975 | 9년 전 | 381 | ||
| 7974 | 9년 전 | 409 | ||
| 7973 | 9년 전 | 618 | ||
| 7972 | 9년 전 | 399 | ||
| 7971 | 9년 전 | 470 | ||
| 7970 | 9년 전 | 320 | ||
| 7969 | 9년 전 | 557 | ||
| 7968 | 9년 전 | 396 | ||
| 7967 | 9년 전 | 387 | ||
| 7966 | 9년 전 | 392 | ||
| 7965 |
|
9년 전 | 1029 | |
| 7964 | 9년 전 | 418 | ||
| 7963 | 9년 전 | 424 | ||
| 7962 | 9년 전 | 404 | ||
| 7961 |
전갈자리남자
|
9년 전 | 518 | |
| 7960 | 9년 전 | 984 | ||
| 7959 | 9년 전 | 563 | ||
| 7958 | 9년 전 | 422 | ||
| 7957 | 9년 전 | 376 | ||
| 7956 | 9년 전 | 377 | ||
| 7955 | 9년 전 | 471 | ||
| 7954 | 9년 전 | 402 | ||
| 7953 | 9년 전 | 450 | ||
| 7952 | 9년 전 | 374 | ||
| 7951 | 9년 전 | 515 | ||
| 7950 | 9년 전 | 408 | ||
| 7949 | 9년 전 | 398 | ||
| 7948 | 9년 전 | 336 | ||
| 7947 | 9년 전 | 948 | ||
| 7946 | 9년 전 | 456 | ||
| 7945 | 9년 전 | 413 | ||
| 7944 | 9년 전 | 452 | ||
| 7943 | 9년 전 | 396 | ||
| 7942 | 9년 전 | 416 | ||
| 7941 | 9년 전 | 410 | ||
| 7940 | 9년 전 | 909 | ||
| 7939 | 9년 전 | 379 | ||
| 7938 | 9년 전 | 411 | ||
| 7937 | 9년 전 | 300 | ||
| 7936 | 9년 전 | 897 | ||
| 7935 | 9년 전 | 474 | ||
| 7934 | 9년 전 | 442 | ||
| 7933 | 9년 전 | 552 | ||
| 7932 | 9년 전 | 513 | ||
| 7931 | 9년 전 | 563 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기