여러게시판 최신글 랜덤추출

여러게시판 최신글 랜덤추출

QA

여러게시판 최신글 랜덤추출

본문

https://sir.kr/g5_tip/4103

안녕하세요?..

위의 팁을 활용하여 여러게시판 최신글을 뽑았는데 여기에 랜덤으로 추출 가능할까요?

이 질문에 댓글 쓰기 :

답변 3

다음과 같이 하시면 되지 않을까 합니다.

 


<?php
// $bo_tables 테이블들 사이 콤마(,) 단위로 구분해서 넣을 것, 콤마 사이에 공백 없이 (ex aaa,bbb,)
function latest_all($skin_dir='', $bo_tables, $rows=10, $subject_len=40, $cache_time=1, $options='')
{
    global $g5;
    if (!$skin_dir) $skin_dir = 'basic';
    if(preg_match('#^theme/(.+)$#', $skin_dir, $match)) {
        if (G5_IS_MOBILE) {
            $latest_skin_path = G5_THEME_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
            if(!is_dir($latest_skin_path))
                $latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
            $latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);
        } else {
            $latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
            $latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);
        }
        $skin_dir = $match[1];
    } else {
        if(G5_IS_MOBILE) {
            $latest_skin_path = G5_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;
            $latest_skin_url  = G5_MOBILE_URL.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;
        } else {
            $latest_skin_path = G5_SKIN_PATH.'/latest/'.$skin_dir;
            $latest_skin_url  = G5_SKIN_URL.'/latest/'.$skin_dir;
        }
    }
    $list = array();
    $sql_common = " from {$g5['board_new_table']} a  where find_in_set(a.bo_table, '{$bo_tables}')";
    $sql_common .= " and a.wr_id = a.wr_parent ";
    $sql_order = " order by a.bn_id desc ";
    $sql = " select a.* {$sql_common} {$sql_order}";
    $result = sql_query($sql);
    
    $row_count = sql_num_rows($result);
    if ($row_count > 0) {
        $rand_row = rand(0, $row_count - 1);
        $sql = " select a.* {$sql_common} {$sql_order} limit {$rand_row}, 1";
        $result = sql_query($sql);
        $row = sql_fetch_array($result);
        $sql = " select * from {$g5['board_table']} where bo_table = '{$row['bo_table']}' ";
        $board = sql_fetch($sql);
        $tmp_write_table = $g5['write_prefix'] . $row['bo_table'];
        $row2 = sql_fetch(" select * from {$tmp_write_table} where wr_id = '{$row['wr_id']}' ");
        $list[0] = get_list($row2, $board, $latest_skin_url, $subject_len);
        $list[0]['bo_subject'] = $row['bo_subject'];
        $list[0]['bo_table'] = $row['bo_table'];
    }
    ob_start();
    include $latest_skin_path.'/latest.skin.php';
    $content = ob_get_contents();
    ob_end_clean();
    return $content;
}
?>

 

$i가 제대로 정의되었고 반복문 안에서 올바르게 증가되는지 확인해 보세요 $i는 일반적으로 여러 항목을 반복 처리하기 위해 반복문 안에서 사용되어야 합니다.

디버깅을 해서 에러의 원인을 찾아서 해결 할 수 있을것으로 보입니다.


for ($i = 0; $i < $row_count; $i++) {
    // ... 기존의 코드 ...

    // 디버깅 문장 추가
    echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";

    // ... 반복문의 나머지 부분 ...
}

위 소스 상단에
for ($i = 0; $i < $row_count; $i++) {
    // ... 기존의 코드 ...

    // 디버깅 문장 추가
    echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";

    // ... 반복문의 나머지 부분 ...
}
이부분을 적용해서 $i 값이 제대로 적용되어 있는지 확인해 보시라는 거였습니다.
$i 값이 정의되지 않았다면  반복문에서 정의를 해주셔야 $list[$i]['bo_subject'] = $board['bo_subject']; 이렇게 했을때 정상 출력이 됩니다.

답변을 작성하시기 전에 로그인 해주세요.
전체 178
QA 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT