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

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

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

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

게시글 목록

번호 제목
23798
23797
23792
23791
23785
23781
23770
23766
23764
23761
23747
23732
23724
23718
23706
23700
23697
23686
23682
23681
23680
23678
23665
23644
23643
23639
23637
23630
23626
23616