批量删除sql里面的有相同前缀的表

有的时候由于本地或者测服务器只有一个数据库,而由于各种原因里面充斥着多个系统的表结构。那时候我删除就要顾及现在远行的系统和以前系统的数据库是否该删除。我们就以删除表前缀的方法来实现。
以下方法已测试!!!!

[b]方法一:(需要服务器支持)直接MYSQL语句。[/b]

SELECT CONCAT( 'drop table ', table_name, ';' ) FROM information_schema.tables WHERE table_name LIKE 'test_%';

[b]方法2:用PHP进行删除。[/b]

<?php
/*xuanfunction 删除数据库中有特定前缀的表
*$dbname 数据库名
*$tableflag 表前缀,这里标志出是哪一个用户,如表s00002_goods前缀为s00002
*/
function deldata($dbname,$tableflag){
$db_host = '125.65.112.14';
$db_port = '3306';
$db_user = 'sq_dayintown';
$db_pass = 'dayintown';
$connect =mysql_connect($db_host,$db_user,$db_pass);
mysql_select_db($dbname);
$result = mysql_query("show table status from $dbname",$connect);
$data=mysql_fetch_array($result);
while($data=mysql_fetch_array($result)) {
$table=mysubstr($data[Name],"_");//截取当前表的下划线以前的字符串得到表前缀
if($table==$tableflag){ //判断截取的前缀是否等于自己需要的前缀$tableflag,如果是就删

除该表
//测试之用
/*echo $data[Name];
echo "<br>";
echo $table;
echo "<br>";*/
mysql_query("drop table $data[Name]");
}
}
return true;
}

/*截取某个特定字符前的所有字符函数
*$str 为待截取字符串
*$flag 特定字符如“_”
*/
function mysubstr($str,$flag){
$pos=strpos($str,$flag);
return substr($str,0,$pos);
}
//test
$dbname="sq_dayintown"; //数据库名
$tableflag="s000002"; //要删除的表的前缀,有这个前缀的表才删除,标志出是哪一个用户


deldata($dbname,$tableflag);
//$test=mysubstr("s000002_account_log","_");

(--end--)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值