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

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

· 2년 전 · 3043 · 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년 전
멋진 팁 고맙습니다.
감사합니다
정말 감사합니다.

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

게시글 목록

번호 제목
24318
24317
24315
24309
24294
24293
24277
24262
24260
24253
24251
24236
24233
24228
24226
24221
24214
24203
24201
24199
24196
24195
24194
24192
24191
24187
24185
24183
24172
24168