php+mysqli实现批量替换数据库表前缀的方法

作者:shichen2014 时间:2023-11-22 10:15:55 

本文实例讲述了php+mysqli实现批量替换数据库表前缀的方法。分享给大家供大家参考。具体分析如下:

在php中有时我们要替换数据库中表前缀但是又不苦于一个个表去修改前缀,这里我自己写了一个mysqli批量替换数据库表前缀的php程序,感兴趣的朋友可以参考一下,代码如下:

<?php
header ( 'http-equiv="Content-Type" content="text/html; charset=utf-8"' );
$DB_host = "localhost"; //数据库主机
$DB_user = "root"; //数据库用户
$DB_psw = "root3306"; //数据库密码
$DB_datebase = "gk_yue39_com"; //数据库名
$DB_charset = "utf8"; //数据库字符集
$dbprefix="yue392_com_";
$new_dbprefix="yue39_com_";
$db = new mysqli ( $DB_host, $DB_user, $DB_psw ); //实例化对象
//检查连接
if (mysqli_connect_errno ()) {
printf ( "Connect failed: %sn", mysqli_connect_error () );
exit ();
}
$db->select_db ( $DB_datebase ); //选择操作数据库
$db->set_charset ( $DB_charset ); //设置数据库字符集
//执行一个查询
$sql = 'show tables';
$result = $db->query ( $sql );
echo $result->num_rows . ' 行结果 ' . $result->field_count . ' 列内容<br/>';
//$result->data_seek('5');//从结果集中第5条开始取结果
echo '<table border="1" cellspacing="0" cellpadding="0" align="center" width="90%">';
//循环输出字段名
//$result->field_seek(2);//从字段集中第2条开始取结果
while ( true == ($field = $result->fetch_field ()) ) {
echo '<th>' . $result->current_field . '_' . $field->name . '(' . $field->length . ')</th>';
}
//循环输出查询结果
while ( true == ($row = $result->fetch_assoc ()) ) {
echo '<tr>';
foreach ( $row as $col ) {
$sql="rename table `".$col."` to `".str_replace ( $dbprefix, $new_dbprefix, $col)."`";
if($db->query ( $sql )){
echo '<td align="center">' . $sql. '</td><td><font color="blue"> success</font></td>';
}else{
echo '<td align="center">' . $sql. '</td><td><font color="red"> failed</font></td>';
}
}
echo '</tr>';
}
echo '</table>';
$result->free ();//释放结果集
$db->close (); //关闭连接
?>

第二种方法:如何批量修改MYSQL的数据库表前缀名称

批量修改表名的操作方法,以下操作请用navicat操作即可,快捷方便:

SELECT CONCAT( ‘ALTER TABLE ‘, TABLE_NAME, ‘RENAME TO ‘, TABLE_NAME,‘;' )
FROM information_schema.TABLES
WHERE TABLE_NAME LIKE ‘uc_%';

执行后得到如下的结果:

ALTER TABLE uc_aaa RENAME TO uc_aaa;
ALTER TABLE uc_bbb RENAME TO uc_bbb;

保留如下的数据:

ALTER TABLE uc_aaa RENAME TO uc_aaa;
ALTER TABLE uc_bbb RENAME TO uc_bbb;

然后选择要修改的数据库,执行上面得到的SQL语句就可以修改掉数据库表前缀了。
附:1、批量删除指定前缀的表

SELECT CONCAT( ‘drop table ‘, TABLE_NAME, ‘;' )
FROM information_schema.TABLES
WHERE TABLE_NAME LIKE ‘uc_%';

2、“dbtable_name”改成“db_table_name”

SELECT CONCAT( ‘ALTER TABLE ‘, TABLE_NAME, ‘RENAME TO db_', SUBSTRING(TABLE_NAME,3),‘;' )
FROM information_schema.TABLES
WHERE TABLE_NAME LIKE ‘db%';

第三种方法:

今天更新一个mysql数据库表前缀的另一个方法,这个方法使用也非常简单,就是用第三方工具——帝国备份王进行修改。操作方法如下:

1、登录帝国备份后台,选择“备份数据”—— “批量替换表名”,然后执行操作就可以完成批量替换了,也非常简单。如下图:

php+mysqli实现批量替换数据库表前缀的方法

 如何批量修改mysql的表前缀名称

以上方法都可修改网站前缀,不过大多数的开源程序修改表缀后,再需要修改网站程序的数据库配置文件,才会让网站网站的运行。

希望本文所述对大家的php程序设计有所帮助。

标签:php,mysqli,方法
0
投稿

猜你喜欢

  • Apache+php+mysql在windows下的安装与配置(图文)第1/2页

    2024-05-11 09:25:34
  • 解决启动django,浏览器显示“服务器拒绝访问”的问题

    2023-08-20 05:45:01
  • SQL Server游标的使用/关闭/释放/优化小结

    2024-01-21 15:37:36
  • asp随机获取access数据库中的一条记录

    2007-08-15 13:11:00
  • 解决Tensorflow 使用时cpu编译不支持警告的问题

    2023-12-30 07:28:01
  • 使用PowerShell实现批量修改或替换文件名

    2023-02-08 05:02:10
  • 一起来学习Python的元组和列表

    2023-07-23 02:43:32
  • Mysql索引创建删除及使用代价

    2024-01-16 15:32:35
  • Keras之fit_generator与train_on_batch用法

    2021-07-10 18:19:31
  • 简单介绍各种浏览器中的本地存储方法

    2012-04-26 16:37:34
  • PHP入门教程之会话控制技巧(cookie与session)

    2023-11-16 00:13:39
  • python读取ini配置文件过程示范

    2023-07-02 01:18:36
  • Pandas中Series的属性,方法,常用操作使用案例

    2021-11-22 05:00:47
  • 一些常用的JavaScript函数(json)附详细说明

    2024-04-10 16:14:12
  • Python 过滤错误log并导出的实例

    2023-10-21 10:18:36
  • Window环境下Scrapy开发环境搭建

    2023-08-24 01:14:58
  • python 如何获取文件夹中的全部文件

    2022-09-10 16:48:11
  • windows下安装make及使用makefile文件

    2023-05-08 07:50:53
  • Bootstrap每天必学之响应式导航、轮播图

    2023-08-15 03:29:45
  • numpy之多维数组的创建全过程

    2023-06-22 03:58:03
  • asp之家 网络编程 m.aspxhome.com