溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

利用php+mysqli怎么對(duì)數(shù)據(jù)庫(kù)表的前綴進(jìn)行替換

發(fā)布時(shí)間:2020-12-24 15:07:33 來(lái)源:億速云 閱讀:124 作者:Leah 欄目:開發(fā)技術(shù)

利用php+mysqli怎么對(duì)數(shù)據(jù)庫(kù)表的前綴進(jìn)行替換?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

在php中有時(shí)我們要替換數(shù)據(jù)庫(kù)中表前綴但是又不苦于一個(gè)個(gè)表去修改前綴,這里我自己寫了一個(gè)mysqli批量替換數(shù)據(jù)庫(kù)表前綴的php程序,感興趣的朋友可以參考一下,代碼如下:

<?php 
header ( 'http-equiv="Content-Type" content="text/html; charset=utf-8"' ); 
$DB_host = "localhost"; //數(shù)據(jù)庫(kù)主機(jī) 
$DB_user = "root"; //數(shù)據(jù)庫(kù)用戶 
$DB_psw = "root3306"; //數(shù)據(jù)庫(kù)密碼 
$DB_datebase = "gk_yue39_com"; //數(shù)據(jù)庫(kù)名 
$DB_charset = "utf8"; //數(shù)據(jù)庫(kù)字符集 
$dbprefix="yue392_com_"; 
$new_dbprefix="yue39_com_"; 
$db = new mysqli ( $DB_host, $DB_user, $DB_psw ); //實(shí)例化對(duì)象 
 
//檢查連接 
if (mysqli_connect_errno ()) { 
 printf ( "Connect failed: %sn", mysqli_connect_error () ); 
 exit (); 
} 
 
$db->select_db ( $DB_datebase ); //選擇操作數(shù)據(jù)庫(kù) 
 
$db->set_charset ( $DB_charset ); //設(shè)置數(shù)據(jù)庫(kù)字符集 
 
//執(zhí)行一個(gè)查詢 
$sql = 'show tables'; 
$result = $db->query ( $sql ); 
 
echo $result->num_rows . ' 行結(jié)果 ' . $result->field_count . ' 列內(nèi)容<br/>'; 
 
//$result->data_seek('5');//從結(jié)果集中第5條開始取結(jié)果 
 
echo '<table border="1" cellspacing="0" cellpadding="0" align="center" width="90%">'; 
 
//循環(huán)輸出字段名 
//$result->field_seek(2);//從字段集中第2條開始取結(jié)果 
while ( true == ($field = $result->fetch_field ()) ) { 
 echo '<th>' . $result->current_field . '_' . $field->name . '(' . $field->length . ')</th>'; 
} 
 
//循環(huán)輸出查詢結(jié)果 
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 ();//釋放結(jié)果集 
$db->close (); //關(guān)閉連接 
?>

第二種方法:如何批量修改MYSQL的數(shù)據(jù)庫(kù)表前綴名稱

批量修改表名的操作方法,以下操作請(qǐng)用navicat操作即可,快捷方便:

復(fù)制代碼 代碼如下:


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

執(zhí)行后得到如下的結(jié)果:

復(fù)制代碼 代碼如下:


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

保留如下的數(shù)據(jù):

復(fù)制代碼 代碼如下:


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

然后選擇要修改的數(shù)據(jù)庫(kù),執(zhí)行上面得到的SQL語(yǔ)句就可以修改掉數(shù)據(jù)庫(kù)表前綴了。
附:1、批量刪除指定前綴的表

復(fù)制代碼 代碼如下:


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

2、“dbtable_name”改成“db_table_name”

復(fù)制代碼 代碼如下:


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

第三種方法:

今天更新一個(gè)mysql數(shù)據(jù)庫(kù)表前綴的另一個(gè)方法,這個(gè)方法使用也非常簡(jiǎn)單,就是用第三方工具——帝國(guó)備份王進(jìn)行修改。操作方法如下:

1、登錄帝國(guó)備份后臺(tái),選擇“備份數(shù)據(jù)”—— “批量替換表名”,然后執(zhí)行操作就可以完成批量替換了,也非常簡(jiǎn)單。如下圖:

利用php+mysqli怎么對(duì)數(shù)據(jù)庫(kù)表的前綴進(jìn)行替換

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI