日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 批量drop_MySql批量drop table

發(fā)布時(shí)間:2025/3/21 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 批量drop_MySql批量drop table 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

今天發(fā)現(xiàn)數(shù)據(jù)庫中很多沒用的表,想清理掉。

發(fā)現(xiàn)mysql好像不支持類似這樣的寫法:drop table like "%r"

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

那么想在mysql中實(shí)現(xiàn),怎么做呢?

兩個(gè)思路:

第一、修改mysql源碼,在drop的時(shí)候加上like關(guān)鍵字支持。

第二、寫一個(gè)腳本,在數(shù)據(jù)庫之外執(zhí)行。

-----------------------------《混個(gè)》-------------------------------

第一個(gè)方法,現(xiàn)在還沒有辦法去做到。【水平不夠=。=】

第二個(gè)方法的思路:

1、連接數(shù)據(jù)庫

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

3、挨個(gè)刪除【刪除過程遇到錯(cuò)誤輸出提示即可】

針對第二個(gè)方法的腳本如下:

先創(chuàng)建一些表:腳本如下

#! /bin/bash

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

do

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

done;

然后創(chuàng)建刪除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%’

需要在后面的參數(shù)中指明要匹配的內(nèi)容。與like關(guān)鍵字后面要加的內(nèi)容一樣。

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

if [ $count -ne 1 -a $count -ne 2 ]意思是說,不考慮第一個(gè)和第二個(gè)參數(shù)。因?yàn)閺膍ysql讀出來的表名稱是這樣的:;

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

前兩個(gè)需要忽略。

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

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

mysql可以用-e參數(shù)來直接執(zhí)行命令。

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

總結(jié)

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

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。