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

여분필드 확장 후 write_update.skin.php

· 2년 전 · 3041 · 36

[code]

<?php

if (!defined("_GNUBOARD_")) exit;

 

$sql = "SELECT bo_table, bo_subject FROM {$g5['board_table']} ORDER BY gr_id, bo_table";
$result = sql_query($sql);

$query = "SHOW COLUMNS FROM " . G5_TABLE_PREFIX . "write_{$bo_table} LIKE 'wr_%'";
$result2 = sql_query($query);

$max_column_num = 0;
$max_column_name = '';
while ($column = sql_fetch_array($result2)) {
    $column_name = $column['Field'];
    $column_num = preg_replace('/[^0-9]/', '', $column_name);
    if ($column_num > $max_column_num) {
        $max_column_num = $column_num;
        $max_column_name = $column_name;
    }
}

$wr_last_num = explode("wr_", $max_column_name)[1];

while ($row = sql_fetch_array($result)) {
    $extra_fields = [];
    for ($k = 11; $k <= $wr_last_num; $k++) {
        $qq = sql_fetch("SHOW COLUMNS FROM " . G5_TABLE_PREFIX . "write_{$row['bo_table']} LIKE 'wr_{$k}'");
        if ($qq) {
            $extra_fields[] = $k;
        }
    }
    
    if (count($extra_fields) > 0) {
        $columns = "";
        foreach ($extra_fields as $i) {
            if (isset(${'wr_'.$i})) {
                $columns .= "wr_$i = '${'wr_'.$i}', ";
            }
        }
        $columns = rtrim($columns, ', ');
        
        if (!empty($columns)) {
            $sql = "UPDATE $write_table SET $columns WHERE wr_id = '$wr_id'";
            sql_query($sql);
        }
    }
}

[/code]

사용하는 게시판에 write_update.skin.php를 위 내용으로 넣으세요.

여분필드 숫자와 크게 관계가 없을 것으로 기대하며 . . .

 

* 첨부파일3은 여분필드 추가/삭제 파일입니다. 아무곳에나 넣고 불러오면 됩니다.(_common.php필요)

댓글 작성

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

로그인하기

댓글 36개

@들레아빠 네 저도 나중에 테스트해보겠습니다. 감사합니다
2년 전
@풍운 네 감사 합니다.
2년 전
멋진 팁 고맙습니다.
감사합니다
정말 감사합니다.

와미쳤다. ㅋㅋ 여분필드 추가안되어서 애먹고있었는데 답변달아주셔서 왔습니다. 잘쓰겠습니다~!! 채택했습니다~!!

게시글 목록

번호 제목
24149
24140
24133
24125
24119
24109
24105
24101
24093
24089
24077
24074
24071
24070
24067
24056
24050
24046
24043
24040
24037
24036
24035
24034
24021
24017
24005
24002
23990
23980