有的时候由于本地或者测服务器只有一个数据库,而由于各种原因里面充斥着多个系统的表结构。那时候我删除就要顾及现在远行的系统和以前系统的数据库是否该删除。我们就以删除表前缀的方法来实现。
以下方法已测试!!!!
[b]方法一:(需要服务器支持)直接MYSQL语句。[/b]
[b]方法2:用PHP进行删除。[/b]
(--end--)
以下方法已测试!!!!
[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--)