GnuBoardバックアップ練習
既存のDBをeuc-krからutf8に変換するために、バックアップを慎重に(??)取って、
editplusで開いたら、現在のエンコーディングに損失される可能性のある文字が含まれていると表示され、
とりあえず無視してUTF8に変更しインポート…クソ、壊れた文字のせいでできませんでしたㅠㅠ
急いで検索~~~~結局解決策が見つからず…
(ダンプする時に-default-character-setまでオプションを与えても、こういう場合はダメなんですよㅠㅠ)
仕方なく以下のソースを見つけて、自分好みに修正しました(UTF8変換、必要なテーブルを選択)
移行確認完了!!!! - 移行するのはやっぱり面倒で疲れますㅠㅠ
[PHP]
$mysql_host = '********';
$mysql_db = '********';
$mysql_user = '********';
$mysql_pass = '********';
$fileName = 'db-backup';
$extention = "sql";
// 必要なテーブルのみ~
$select[] = 'g4_board';
$select[] = 'g4_board_file';
$select[] = 'g4_board_good';
$select[] = 'g4_board_new';
$select[] = 'g4_config';
$select[] = 'g4_group';
$select[] = 'g4_group_member';
$select[] = 'g4_write_cast';
$select[] = 'g4_write_delphibbs';
$select[] = 'g4_write_english';
$select[] = 'g4_write_girl';
$select[] = 'g4_write_gy';
$select[] = 'g4_write_humor';
$select[] = 'g4_write_module';
$select[] = 'g4_write_mypage';
$select[] = 'g4_write_notice';
$select[] = 'g4_write_poll';
$select[] = 'g4_write_qna';
$select[] = 'g4_write_skin';
$select[] = 'g4_write_talk';
$select[] = 'g4_write_temp';
$select[] = 'g4_write_temppds';
$select[] = 'g4_write_test';
$select[] = 'g4_write_tiptech';
$select[] = 'g4_write_varios';
$all = false; // 完全なInsert文を書くならtrue
$drop = true; // drop table文を含むならtrue
mysql_connect( $mysql_host, $mysql_user, $mysql_pass ) || die("データベース接続に失敗しました。");
mysql_select_db( $mysql_db ) || die("DB接続に失敗");
function bak_getTableNames($db)
{
$result[0] = mysql_list_tables($db);
$result[1] = mysql_num_rows($result[0]);
return $result;
}
function bak_getFields($table)
{
global $all;
$result = mysql_query("show fields from $table");
$i = 0;
while($keys = mysql_fetch_array($result))
{
if(!$i) $defaultOrder = $keys[Field];
if($keys[Key] == 'PRI')
{
$orderby = $keys[Field];
break;
}
$i++;
}
if(!$orderby) $orderby = $defaultOrder;
$result = mysql_query("select * from $table order by $orderby");
$nums = mysql_num_fields($result);
if($all == true)
{
for($i=0;$i<$nums;$i++)
{
$fields[] = mysql_field_name($result,$i);
}
$fields = "(".implode(",",$fields).") ";
}
while($rows = mysql_fetch_row($result))
{
for($i=0;$i<$nums;$i++)
{
$temp = $rows[$i];
$temp = str_replace("'","''", $temp);
$temp = str_replace("","", $temp);
$temp = str_replace("n",'n', $temp);
$temp = str_replace("r",'r', $temp);
$temp = iconv('CP949', 'UTF-8', $temp);
$insertValues[$i] = $temp;
}
$return .= "INSERT INTO $table ".$fields."values ('".implode("','",
$insertValues)."');n";
}
return $return;
}
$tables = bak_getTableNames($mysql_db);
if($tables[1] > 0)
{
$backText = ”
# MysqlDump
# ホスト: “.$mysql_host.”
# 処理時間: “.date(‘Y年 n月 j日 H時 i分’).”
# サーバーバージョン: “.mysql_get_server_info().”
# データベース: `”.$mysql_db.”`
# ——————————————————–nnnnn”;
while($rows = mysql_fetch_row($tables[0]))
{
$chk = false;
for($i=0;$i
[/PHP]











Leave a Reply