특정게시판의 글쓴 회원글수 표기하기

특정게시판의 글쓴 회원글수 표기하기

QA

특정게시판의 글쓴 회원글수 표기하기

답변 1

본문

특정 게시판 가령 (포럼 게시판)에

회원들이 글쓴 개수를 리스트에 표기를 해주려고 하는데요

(포럼게시판이면 포럼게시판에다가 쓴 글 숫자 // 타 게시판에 글쓴건 제외)

ex. 제가 포럼게시판에 글을 10개 적었으면 10 이라는 숫자가 표기되도록

 


<?
$sql = " select count(*) as cnt from `g5_write_forum` where mb_id = '{$list['mb_id']}' ";
$row = sql_fetch($sql);
$count = $row['cnt'];
?>

 

찍어봐도 숫자가 계속 0으로만 나오는데 <?=$count?>

진짜 초보라 뭐가 잘못된건지 잘 모르겠습니다 ㅠ .ㅠ

 

혹시 좋은 지혜있으면 살짝 나눠주세요

 

3690604473_1664686556.4132.jpg

 

 

 

 

이 질문에 댓글 쓰기 :

답변 1

$list['mb_id']

가 아닌

 

$list[$i]['mb_id']

가 아닐까 추측해봅니다.

대략 이런식으로요.


<?php

// $write_count_map = [];
// $list 에서 mb_id, write count 만 따로 추출해 $write_count_map 에 추가
// select mb_id, count(1) cnt from ... where mb_id IN ('member1', 'member2', ...) group by mb_id
// $write_count_map = ['member1' => 0, 'member2' => 2, ...];

for ($i = 0; $i < count($list); $i++) {
    // $sql = " select count(*) as cnt from ... {$list[$i]['mb_id']} ";
    // $row = sql_fetch($sql);
    // $count = $row['cnt'];

    $count = 0;
    if (empty($write_count_map[$list[$i]['mb_id']]) === false) {
        $count = $write_count_map[$list[$i]['mb_id']];
    }
}
?>


한페이지에 목록 500 개 설정한 경우라면 500번 실행될 쿼리 1번으로 줄겠죠.
단 이럴경우 mb_id 에 인덱스 까지 있어야 합니다.
인덱스 없으면 차라리 개별 쿼리가 낫고요

답변을 작성하시기 전에 로그인 해주세요.
QA 내용 검색
질문등록
전체 125,873
© SIRSOFT
현재 페이지 제일 처음으로