日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

mysql 批量drop_MySql批量drop table

發布時間:2025/3/21 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 批量drop_MySql批量drop table 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天發現數據庫中很多沒用的表,想清理掉。

發現mysql好像不支持類似這樣的寫法:drop table like "%r"

在oracle中,查了資料,是可以通過其他方式來實現:看這里【我頂!鏈接丟了!】

那么想在mysql中實現,怎么做呢?

兩個思路:

第一、修改mysql源碼,在drop的時候加上like關鍵字支持。

第二、寫一個腳本,在數據庫之外執行。

-----------------------------《混個》-------------------------------

第一個方法,現在還沒有辦法去做到。【水平不夠=。=】

第二個方法的思路:

1、連接數據庫

2、查詢出所有的符合條件的表

3、挨個刪除【刪除過程遇到錯誤輸出提示即可】

針對第二個方法的腳本如下:

先創建一些表:腳本如下

#! /bin/bash

for((i=1;i<=10;i++));

do

mysql -P3307 -uroot -proot -e"use test;create table tb_$i(id int);"

done;

然后創建刪除shell:

#! /bin/bash

word=`echo $1`

params=`echo $#`

echo "your input param is|"$word"|"

#param is ok?

if [ $params -lt 1 ]

then

echo "usage:drop 'yourword'"

exit

fi

#connect mysql and read tb names

var=$(mysql -P3307 -uroot -proot -e"use test;show tables like '$word';")

count=0

#read table names

for i in $var;

do

let count=$count+1

if [ $count -ne 1 -a $count -ne 2 ]

then

#delete from db

echo "deleting ...$i"

mysql -P3307 -uroot -proot -e"use test;drop table $i"

fi

done;

上面是drop腳本。使用方法:

drop ‘%a%’

需要在后面的參數中指明要匹配的內容。與like關鍵字后面要加的內容一樣。

腳本中每次執行都需要連接數據庫。效率比較低下。但是對于少量的表,不會有太大區別。----------------------------------------------------------

if [ $count -ne 1 -a $count -ne 2 ]意思是說,不考慮第一個和第二個參數。因為從mysql讀出來的表名稱是這樣的:;

Tables_in_test () tb_1 tb_10 tb_2 tb_3 tb_4 tb_5 tb_6 tb_7 tb_8 tb_9

前兩個需要忽略。

--------------------------------------------------------------

mysql -P3307 -uroot -proot -e"use test;show tables like '$word';"

mysql可以用-e參數來直接執行命令。

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的mysql 批量drop_MySql批量drop table的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。