Welcome 微信登录

首页 / 数据库 / MySQL / 修复 MySQL页面正常 数据库文件sql乱码

MySQL 页面正常 数据库文件sql乱码
如果你的库原来是gbk编码,则把以下代码存为php文件,记得把下面的数据库名跟数据库帐号密码填上<?php
define("DB_NAME", "putyourdbnamehere");    // 数据库名
define("DB_USER", "usernamehere");     // MySQL用户名
define("DB_PASSWORD", "yourpasswordhere"); // 密码
define("DB_HOST", "localhost");    // 很大可能你无需修改此项function gbk_DB_Converter_DoIt() {
 $tables = array();
 $tables_with_fields = array(); // Since we cannot use the WordPress Database Abstraction Class (wp-db.php),
 // we have to make an a stand-alone/direct connection to the database.
 $link_id = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD) or die("Error establishing a database connection");
 mysql_select_db(DB_NAME, $link_id); // Gathering information about tables and all the text/string fields that can be affected
 // during the conversion to gbk.
 $resource = mysql_query("SHOW TABLES", $link_id);
 while ( $result = mysql_fetch_row($resource) )
  $tables[] = $result[0]; if ( !empty($tables) ) {
  foreach ( (array) $tables as $table ) {
   $resource = mysql_query("EXPLAIN $table", $link_id);
   while ( $result = mysql_fetch_assoc($resource) ) {
    if ( preg_match("/(char)|(text)|(enum)|(set)/", $result["Type"]) )
     $tables_with_fields[$table][$result["Field"]] = $result["Type"] . " " . ( "YES" == $result["Null"] ? "" : "NOT " ) . "NULL " .  ( !is_null($result["Default"]) ? "DEFAULT "". $result["Default"] .""" : "" );
   }
  }  // Change all text/string fields of the tables to their corresponding binary text/string representations.
  foreach ( (array) $tables as $table )
   mysql_query("ALTER TABLE $table CONVERT TO CHARACTER SET binary", $link_id);  // Change database and tables to gbk Character set.
  mysql_query("ALTER DATABASE " . DB_NAME . " CHARACTER SET gbk", $link_id);
  foreach ( (array) $tables as $table )
   mysql_query("ALTER TABLE $table CONVERT TO CHARACTER SET gbk", $link_id);  // Return all binary text/string fields previously changed to their original representations.
  foreach ( (array) $tables_with_fields as $table => $fields ) {
   foreach ( (array) $fields as $field_type => $field_options ) {
    mysql_query("ALTER TABLE $table MODIFY $field_type $field_options", $link_id);
   }
  }  // Optimize tables and finally close the mysql link.
  foreach ( (array) $tables as $table )
   mysql_query("OPTIMIZE TABLE $table", $link_id);
  mysql_close($link_id);
 } else {
  die("<strong>There are no tables?</strong>");
 } return true;
}
gbk_DB_Converter_DoIt();
?>随便放到一个可以访问到库的php站点下运行即可。 如果你的库是utf-8编码,则运行以下代码,记得把下面的数据库名跟数据库帐号密码填上<?php
define("DB_NAME", "putyourdbnamehere");    // 数据库名
define("DB_USER", "usernamehere");     // MySQL用户名
define("DB_PASSWORD", "yourpasswordhere"); // 密码
define("DB_HOST", "localhost");    // 很大可能你无需修改此项

function UTF8_DB_Converter_DoIt() {
$tables = array();
$tables_with_fields = array();

// Since we cannot use the WordPress Database Abstraction Class (wp-db.php),
// we have to make an a stand-alone/direct connection to the database.
$link_id = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD) or die("Error establishing a database connection");
mysql_select_db(DB_NAME, $link_id);

// Gathering information about tables and all the text/string fields that can be affected
// during the conversion to UTF-8.
$resource = mysql_query("SHOW TABLES", $link_id);
while ( $result = mysql_fetch_row($resource) )
$tables[] = $result[0];

if ( !empty($tables) ) {
foreach ( (array) $tables as $table ) {
$resource = mysql_query("EXPLAIN $table", $link_id);
while ( $result = mysql_fetch_assoc($resource) ) {
if ( preg_match("/(char)|(text)|(enum)|(set)/", $result["Type"]) )
$tables_with_fields[$table][$result["Field"]] = $result["Type"] . " " . ( "YES" == $result["Null"] ? "" : "NOT " ) . "NULL " .  ( !is_null($result["Default"]) ? "DEFAULT "". $result["Default"] .""" : "" );
}
}

// Change all text/string fields of the tables to their corresponding binary text/string representations.
foreach ( (array) $tables as $table )
mysql_query("ALTER TABLE $table CONVERT TO CHARACTER SET binary", $link_id);

// Change database and tables to UTF-8 Character set.
mysql_query("ALTER DATABASE " . DB_NAME . " CHARACTER SET utf8", $link_id);
foreach ( (array) $tables as $table )
mysql_query("ALTER TABLE $table CONVERT TO CHARACTER SET utf8", $link_id);

// Return all binary text/string fields previously changed to their original representations.
foreach ( (array) $tables_with_fields as $table => $fields ) {
foreach ( (array) $fields as $field_type => $field_options ) {
mysql_query("ALTER TABLE $table MODIFY $field_type $field_options", $link_id);
}
}

// Optimize tables and finally close the mysql link.
foreach ( (array) $tables as $table )
mysql_query("OPTIMIZE TABLE $table", $link_id);
mysql_close($link_id);
} else {
die("<strong>There are no tables?</strong>");
}

return true;
}
UTF8_DB_Converter_DoIt();
?>
运行完之后登录phpmyadmin,查询下就知道乱码已经恢复!Oracle 行级锁与表级锁Oralce中的synonym同义词相关资讯      MySQL基础教程 
  • MySQL基础教程:关于varchar(N)  (01月22日)
  • MySQL SELECT同时UPDATE同一张表  (02/19/2013 07:20:18)
  • Linux修改MySQL最大并发连接数  (02/15/2013 15:37:21)
  • 高性能MySQL(第3版) 中文PDF带目  (10/26/2014 10:03:50)
  • 如何在MySQL中的获取IP地址的网段  (02/18/2013 12:23:33)
  • C++和C#访问MySQL的简单代码示例  (12/21/2012 09:04:10)
本文评论 查看全部评论 (0)
表情: 姓名: 字数