2026, 새로운 도약을 시작합니다.

전체 게시판에서 내가 작성한 게시글 / 댓글 개수 가져오기

978180634_1713937124.8766.png

이번에 업데이트 하는 과정에서 나온 코드입니다.

내가 활동한 전체 게시판의 게시글 내역수 + 댓글 내역수를 출력하고자 하는 데 목적이 있습니다.

원하는 페이지에 코드를 넣으시면 끝입니다.

[code]

<?php

function getUserBoardActivity(array $exclude_boards = []) {

    global $member;  // 회원 정보를 가져옵니다.

    // 배열을 SQL 쿼리에서 사용할 수 있는 문자열로 변환

    $exclude_clause = '';

    if (!empty($exclude_boards)) {

        $exclude_boards_string = "'" . implode("', '", $exclude_boards) . "'";

        $exclude_clause = " WHERE `bo_table` NOT IN ({$exclude_boards_string})";

    }

    // 제외할 게시판을 제외한 모든 게시판 정보를 가져옵니다.

    $sql = "SELECT * FROM `g5_board`" . $exclude_clause;

    $result = sql_query($sql); // 쿼리 실행

    $all_boards_info = [];  // 모든 게시판 정보를 저장할 배열

    while ($board = sql_fetch_array($result)) {

        $bo_table = $board['bo_table'];  // 게시판 테이블명을 가져옵니다.

        $bo_subject = $board['bo_subject'];  // 게시판 제목을 가져옵니다.

        // 해당 게시판에서 회원의 게시글 수를 구하는 쿼리

        $query = "SELECT COUNT(*) AS count FROM g5_write_{$bo_table} WHERE mb_id = '{$member['mb_id']}' AND wr_is_comment = '0'";

        $write_count_result = sql_query($query);

        $write_count = sql_fetch_array($write_count_result)['count'];

        // 해당 게시판에서 회원의 댓글 수를 구하는 쿼리

        $query2 = "SELECT COUNT(*) AS count FROM g5_write_{$bo_table} WHERE mb_id = '{$member['mb_id']}' AND wr_is_comment = '1'";

        $comment_count_result = sql_query($query2);

        $comment_count = sql_fetch_array($comment_count_result)['count'];

        // 각 게시판 정보를 배열에 저장

        $all_boards_info[] = array(

            'bo_subject' => $bo_subject,

            'total_write_count' => $write_count,

            'total_comment_count' => $comment_count

        );

    }

    return $all_boards_info;  // 모든 게시판 정보를 배열로 반환

}

// $results = getUserBoardActivity(["free", "notice"]); // 자유게시판 및 공지사항 게시판을 제외한 모든 게시판 정보를 가져옵니다.

$results = getUserBoardActivity(); // 전체 게시판 정보를 가져 옵니다.

foreach ($results as $result) {

    echo "게시판: " . $result['bo_subject'] . "<br>";

    echo "작성한 게시글 수: " . $result['total_write_count'] . "<br>";

    echo "작성한 댓글 수: " . $result['total_comment_count'] . "<br>";

}

?>

[/code]

전체 다 가져오는 코드 / 제외 코드 (주석) 포함하였으니 참고하셔서 사용하시면 될 것 같습니다.

위 코드를 그대로 원하는 페이지에 넣으시면 아래 처럼 결과를 얻을 수 있으며, 원하는데로 스타일링 해서 사용하시면 됩니다.

978180634_1713937325.1461.png

고맙습니다.

|

댓글 3개

감사합니다 ^^

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

그누보드5 팁자료실

번호 제목 글쓴이 날짜 조회
공지 3년 전 조회 4,598
2741 4일 전 조회 124
2740 5일 전 조회 112
2739 1주 전 조회 212
2738 1주 전 조회 218
2737 1주 전 조회 182
2736 2주 전 조회 281
2735 3주 전 조회 286
2734 3주 전 조회 264
2733 1개월 전 조회 266
2732 1개월 전 조회 301
2731 1개월 전 조회 268
2730 1개월 전 조회 227
2729 1개월 전 조회 359
2728 1개월 전 조회 245
2727 1개월 전 조회 422
2726 1개월 전 조회 257
2725 1개월 전 조회 332
2724 1개월 전 조회 361
2723 1개월 전 조회 267
2722 1개월 전 조회 300
2721 1개월 전 조회 213
2720 2개월 전 조회 304
2719 2개월 전 조회 307
2718 2개월 전 조회 202
2717 2개월 전 조회 337
2716 2개월 전 조회 202
2715 2개월 전 조회 313
2714 2개월 전 조회 273
2713 2개월 전 조회 377
2712 2개월 전 조회 289
🐛 버그신고