하나의 테이블에서 원글의 답글과 댓글의 답글을 모두 해결하는 방식을 찾고자 합니다.
테이블의 구조를 다음과 같이 구성합니다.
컬럼명 |
종류 | 설명 |
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년 전 | 356 | ||
| 8029 | 9년 전 | 296 | ||
| 8028 | 9년 전 | 257 | ||
| 8027 | 9년 전 | 270 | ||
| 8026 | 9년 전 | 325 | ||
| 8025 | 9년 전 | 373 | ||
| 8024 | 9년 전 | 337 | ||
| 8023 | 9년 전 | 386 | ||
| 8022 | 9년 전 | 312 | ||
| 8021 | 9년 전 | 323 | ||
| 8020 | 9년 전 | 311 | ||
| 8019 | 9년 전 | 337 | ||
| 8018 | 9년 전 | 440 | ||
| 8017 | 9년 전 | 532 | ||
| 8016 | 9년 전 | 321 | ||
| 8015 | 9년 전 | 383 | ||
| 8014 | 9년 전 | 319 | ||
| 8013 | 9년 전 | 230 | ||
| 8012 | 9년 전 | 239 | ||
| 8011 | 9년 전 | 441 | ||
| 8010 | 9년 전 | 295 | ||
| 8009 | 9년 전 | 276 | ||
| 8008 | 9년 전 | 282 | ||
| 8007 | 9년 전 | 423 | ||
| 8006 | 9년 전 | 458 | ||
| 8005 |
|
9년 전 | 964 | |
| 8004 | 9년 전 | 345 | ||
| 8003 | 9년 전 | 413 | ||
| 8002 | 9년 전 | 320 | ||
| 8001 |
|
9년 전 | 663 | |
| 8000 | 9년 전 | 411 | ||
| 7999 | 9년 전 | 369 | ||
| 7998 | 9년 전 | 423 | ||
| 7997 | 9년 전 | 305 | ||
| 7996 | 9년 전 | 530 | ||
| 7995 | 9년 전 | 452 | ||
| 7994 | 9년 전 | 320 | ||
| 7993 | 9년 전 | 379 | ||
| 7992 | 9년 전 | 502 | ||
| 7991 | 9년 전 | 244 | ||
| 7990 | 9년 전 | 269 | ||
| 7989 | 9년 전 | 296 | ||
| 7988 | 9년 전 | 720 | ||
| 7987 | 9년 전 | 417 | ||
| 7986 | 9년 전 | 407 | ||
| 7985 | 9년 전 | 504 | ||
| 7984 | 9년 전 | 425 | ||
| 7983 | 9년 전 | 655 | ||
| 7982 | 9년 전 | 508 | ||
| 7981 | 9년 전 | 460 | ||
| 7980 | 9년 전 | 487 | ||
| 7979 | 9년 전 | 456 | ||
| 7978 | 9년 전 | 440 | ||
| 7977 | 9년 전 | 380 | ||
| 7976 | 9년 전 | 845 | ||
| 7975 | 9년 전 | 357 | ||
| 7974 | 9년 전 | 386 | ||
| 7973 | 9년 전 | 590 | ||
| 7972 | 9년 전 | 375 | ||
| 7971 | 9년 전 | 453 | ||
| 7970 | 9년 전 | 289 | ||
| 7969 | 9년 전 | 537 | ||
| 7968 | 9년 전 | 377 | ||
| 7967 | 9년 전 | 363 | ||
| 7966 | 9년 전 | 365 | ||
| 7965 |
|
9년 전 | 1008 | |
| 7964 | 9년 전 | 395 | ||
| 7963 | 9년 전 | 387 | ||
| 7962 | 9년 전 | 368 | ||
| 7961 |
전갈자리남자
|
9년 전 | 502 | |
| 7960 | 9년 전 | 957 | ||
| 7959 | 9년 전 | 548 | ||
| 7958 | 9년 전 | 401 | ||
| 7957 | 9년 전 | 362 | ||
| 7956 | 9년 전 | 365 | ||
| 7955 | 9년 전 | 443 | ||
| 7954 | 9년 전 | 369 | ||
| 7953 | 9년 전 | 421 | ||
| 7952 | 9년 전 | 349 | ||
| 7951 | 9년 전 | 497 | ||
| 7950 | 9년 전 | 382 | ||
| 7949 | 9년 전 | 382 | ||
| 7948 | 9년 전 | 321 | ||
| 7947 | 9년 전 | 927 | ||
| 7946 | 9년 전 | 423 | ||
| 7945 | 9년 전 | 389 | ||
| 7944 | 9년 전 | 415 | ||
| 7943 | 9년 전 | 369 | ||
| 7942 | 9년 전 | 401 | ||
| 7941 | 9년 전 | 384 | ||
| 7940 | 9년 전 | 876 | ||
| 7939 | 9년 전 | 347 | ||
| 7938 | 9년 전 | 377 | ||
| 7937 | 9년 전 | 272 | ||
| 7936 | 9년 전 | 878 | ||
| 7935 | 9년 전 | 439 | ||
| 7934 | 9년 전 | 408 | ||
| 7933 | 9년 전 | 502 | ||
| 7932 | 9년 전 | 471 | ||
| 7931 | 9년 전 | 525 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기