테스트 사이트 - 개발 중인 베타 버전입니다

여러게시판 최신글 랜덤추출 채택완료

angpang 1년 전 조회 1,906

https://sir.kr/g5_tip/4103

안녕하세요?..

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

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

답변 3개

채택된 답변
+20 포인트

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

 

</p>

<p><?php

// $bo_tables 테이블들 사이 콤마(,) 단위로 구분해서 넣을 것, 콤마 사이에 공백 없이 (ex aaa,bbb,)

function latest_all($skin_dir='', $bo_tables, $rows=10, $subject_len=40, $cache_time=1, $options='')

{</p>

<p>    global $g5;</p>

<p>    if (!$skin_dir) $skin_dir = 'basic';</p>

<p>    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;

        }

    }</p>

<p>    $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}";</p>

<p>    $result = sql_query($sql);

    

    $row_count = sql_num_rows($result);</p>

<p>    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);</p>

<p>        $row = sql_fetch_array($result);</p>

<p>        $sql = " select * from {$g5['board_table']} where bo_table = '{$row['bo_table']}' ";</p>

<p>        $board = sql_fetch($sql);</p>

<p>        $tmp_write_table = $g5['write_prefix'] . $row['bo_table'];

        $row2 = sql_fetch(" select * from {$tmp_write_table} where wr_id = '{$row['wr_id']}' ");</p>

<p>        $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'];

    }</p>

<p>    ob_start();

    include $latest_skin_path.'/latest.skin.php';

    $content = ob_get_contents();

    ob_end_clean();</p>

<p>    return $content;

}

?>

 

로그인 후 평가할 수 있습니다

답변에 대한 댓글 4개

a
angpang
1년 전
오..감사합니다..
게시판 제목 추출때문에
$list[0]['bo_subject'] = $row['bo_subject'];를
$list[$i]['bo_subject'] = $board['bo_subject']; 이렇게 바꿨더니.. 로딩되고 사이트가 안열리네요..방법이 있는지요
웹메이킹
1년 전
$i가 제대로 정의되었고 반복문 안에서 올바르게 증가되는지 확인해 보세요 $i는 일반적으로 여러 항목을 반복 처리하기 위해 반복문 안에서 사용되어야 합니다.

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

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

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

// ... 반복문의 나머지 부분 ...
}
[/code]
a
angpang
1년 전
lib파일, latest파일 어디에도

for ($i = 0; $i < $row_count; $i++) {
라는 소스가 안보여서요..제가 초보라 디버딩 어디를 만져야될지..^^;답변 감사합니다..
웹메이킹
1년 전
위 소스 상단에
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']; 이렇게 했을때 정상 출력이 됩니다.

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

1년 전

ob_start();

->

shuffle($list);

ob_start();

로그인 후 평가할 수 있습니다

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

1년 전

안녕하세요。

코드를 수정하면 랜덤으로 추출도 가능합니다。

로그인 후 평가할 수 있습니다

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

답변을 작성하려면 로그인이 필요합니다.

로그인