도저히 모르겠어서 질문 드립니다. SQL문...

도저히 모르겠어서 질문 드립니다. SQL문...

QA

도저히 모르겠어서 질문 드립니다. SQL문...

본문

function update_category_rankings($url_path, $board_name) {
    $sql = "SELECT wr_id, wr_subject, CAST(wr_10 AS UNSIGNED) AS wr_10, 
                COALESCE(wr_good, 0) AS wr_good
            FROM g5_write_{$url_path}
            WHERE wr_10 IS NOT NULL AND wr_nogood < 1
            ORDER BY (wr_10 * 1.5 + wr_good * 1.3) DESC
            LIMIT 100";

    $result = sql_query($sql);
    $rank = 1;

    while ($row = sql_fetch_array($result)) {
        $score = ($row['wr_10'] * 0.7) + ($row['wr_good'] * 1.3);

        $prev_category_rank_sql = "SELECT category_rank FROM g5_rank_list WHERE wr_id = '{$row['wr_id']}' AND url_path = '{$url_path}' ORDER BY id DESC LIMIT 1";
        $prev_category_rank_result = sql_query($prev_category_rank_sql);
        $prev_category_rank_row = sql_fetch_array($prev_category_rank_result);
        $previous_category_rank = $prev_category_rank_row ? $prev_category_rank_row['category_rank'] : null;

        $upsert_sql = "INSERT INTO g5_rank_list 
                       (wr_id, category_rank, previous_category_rank, subject, score, good, board_name, url_path) 
                       VALUES (
                           '{$row['wr_id']}', 
                           {$rank}, 
                           " . ($previous_category_rank !== null ? $previous_category_rank : "NULL") . ", 
                           '" . sql_real_escape_string($row['wr_subject']) . "', 
                           {$score}, 
                           {$row['wr_good']}, 
                           '{$board_name}', 
                           '{$url_path}'
                       ) 
                       ON DUPLICATE KEY UPDATE 
                       category_rank = VALUES(category_rank), 
                       previous_category_rank = VALUES(previous_category_rank), 
                       subject = VALUES(subject), 
                       score = VALUES(score), 
                       good = VALUES(good)";
        
        sql_query($upsert_sql);
        $rank++;
    }
}

 

function update_overall_rankings() {
    $sql = "SELECT wr_id, wr_subject, CAST(wr_10 AS UNSIGNED) AS wr_10, 
                COALESCE(wr_good, 0) AS wr_good
            FROM g5_write_all
            WHERE wr_10 IS NOT NULL AND wr_nogood < 1
            ORDER BY (wr_10 * 1.5 + wr_good * 1.3) DESC
            LIMIT 100";

    $result = sql_query($sql);
    $rank = 1;

    while ($row = sql_fetch_array($result)) {
        $score = ($row['wr_10'] * 0.7) + ($row['wr_good'] * 1.3);

        $prev_overall_rank_sql = "SELECT overall_rank FROM g5_rank_list WHERE wr_id = '{$row['wr_id']}' ORDER BY id DESC LIMIT 1";
        $prev_overall_rank_result = sql_query($prev_overall_rank_sql);
        $prev_overall_rank_row = sql_fetch_array($prev_overall_rank_result);
        $previous_overall_rank = $prev_overall_rank_row ? $prev_overall_rank_row['overall_rank'] : null;

        $upsert_sql = "INSERT INTO g5_rank_list 
                       (wr_id, overall_rank, previous_overall_rank, subject, score, good, board_name, url_path) 
                       VALUES (
                           '{$row['wr_id']}', 
                           {$rank}, 
                           " . ($previous_overall_rank !== null ? $previous_overall_rank : "NULL") . ", 
                           '" . sql_real_escape_string($row['wr_subject']) . "', 
                           {$score}, 
                           {$row['wr_good']},
                           'ALL',
                           'all'
                       ) 
                       ON DUPLICATE KEY UPDATE 
                       overall_rank = VALUES(overall_rank), 
                       previous_overall_rank = VALUES(previous_overall_rank), 
                       subject = VALUES(subject), 
                       score = VALUES(score), 
                       good = VALUES(good),
                       board_name = 'ALL',
                       url_path = 'all'";
        
        sql_query($upsert_sql);
        $rank++;
    }
}

소스는 대략 이렇습니다. 전체 카운터와 카테고리 카운터를 등록을 하려고 하는데 카운터가 카테고리는 등록이 되는데 전체 필드가 등록이 안되는 현상입니다.

overall_rank, previous_overall_rank 이 두개의 필드가 죽어도 안들어가네요...데이터가 숫자가 들어가야 하는데 DB를 봐도 안들어가 있고 희안한건 category_rank, previous_category_rank 이것 두개는 데이터가 들어갑니다...ㅠㅠ 고수님들 도와주세요..

이 질문에 댓글 쓰기 :

답변 3

쿼리를 직접 찍어서 확인해 보시고 phpMyAdmin에서 직접 쿼리를 실행해서 문제를 체크해 보셔야 할듯 합니다.

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

회원로그인

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