使用Shell腳本操作多個MySQL數據庫的步驟詳解
使用 Shell 腳本操作多個 MySQL 數據庫
步驟 1: 數據庫信息文件
首先準備一個包含三個 MySQL 數據庫信息的文件,例如 db_info.txt。文件內容如下:
192.168.1.100 3306 root rootpassword1 database1 192.168.1.100 3307 root rootpassword2 database2 192.168.1.100 3308 root rootpassword3 database3
每行表示一個數據庫,字段順序為:
- 主機地址
- 端口號
- 用戶名
- 密碼
- 數據庫名稱
步驟 2: 創(chuàng)建 Shell 腳本
編寫以下腳本,命名為 create_tables.sh。
#!/bin/bash
# 數據庫信息文件路徑
DB_INFO_FILE="db_info.txt"
# 要執(zhí)行的 SQL 文件
SQL_FILE="create_table.sql"
# 檢查數據庫信息文件是否存在
if [[ ! -f "$DB_INFO_FILE" ]]; then
echo "數據庫信息文件 $DB_INFO_FILE 不存在!"
exit 1
fi
# 檢查 SQL 文件是否存在
if [[ ! -f "$SQL_FILE" ]]; then
echo "SQL 文件 $SQL_FILE 不存在!"
exit 1
fi
# 遍歷數據庫信息文件
while read -r HOST PORT USER PASSWORD DATABASE; do
# 確保讀取的字段完整
if [[ -z "$HOST" || -z "$PORT" || -z "$USER" || -z "$PASSWORD" || -z "$DATABASE" ]]; then
echo "數據庫信息文件格式不正確,跳過行:$HOST $PORT $USER $DATABASE"
continue
fi
echo "連接到數據庫 $DATABASE ($HOST:$PORT)..."
# 使用 mysql 命令執(zhí)行 SQL 文件
mysql -h "$HOST" -P "$PORT" -u "$USER" -p"$PASSWORD" "$DATABASE" < "$SQL_FILE"
# 檢查執(zhí)行結果
if [[ $? -eq 0 ]]; then
echo "SQL 文件已成功執(zhí)行到 $DATABASE。"
else
echo "SQL 文件執(zhí)行到 $DATABASE 失敗!"
fi
echo "--------------------------------------"
done < "$DB_INFO_FILE"
步驟 3: 創(chuàng)建 SQL 文件
準備一個示例 SQL 文件 create_table.sql,內容如下:
CREATE TABLE IF NOT EXISTS example_table (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(255) NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
步驟 4: 設置腳本權限并執(zhí)行
為腳本賦予執(zhí)行權限:
chmod +x create_tables.sh
執(zhí)行腳本:
./create_tables.sh
執(zhí)行流程:
- 腳本會讀取
db_info.txt文件中的數據庫信息。 - 遍歷每個數據庫,并通過
mysql命令連接。 - 對每個數據庫執(zhí)行
create_table.sql中的 SQL 語句。 - 顯示每個數據庫的執(zhí)行結果。
示例輸出:
連接到數據庫 database1 (192.168.1.100:3306)... SQL 文件已成功執(zhí)行到 database1。 -------------------------------------- 連接到數據庫 database2 (192.168.1.100:3307)... SQL 文件已成功執(zhí)行到 database2。 -------------------------------------- 連接到數據庫 database3 (192.168.1.100:3308)... SQL 文件已成功執(zhí)行到 database3。 --------------------------------------
這樣,腳本可以靈活地從文件中讀取多個數據庫信息,并完成指定的 SQL 文件執(zhí)行操作!
到此這篇關于使用Shell腳本操作多個MySQL數據庫的步驟詳解的文章就介紹到這了,更多相關Shell腳本操作多個MySQL數據庫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解決MySQL8.0本地計算機上的MySQL服務啟動后停止沒有報告任何錯誤的問題(最新推薦)
解決MySQL服務啟動后停止沒有報告任何錯誤的方法包括修改my.ini文件編碼為ANSI、修正MySQL服務可執(zhí)行文件的路徑以及關閉系統(tǒng)管理中的MySQL80服務,本文介紹解決MySQL8.0本地計算機上的MySQL服務啟動后停止沒有報告任何錯誤,感興趣的朋友一起看看吧2025-03-03
linux下mysql開啟遠程訪問權限 防火墻開放3306端口
這篇文章主要為大家詳細介紹了linux下mysql開啟遠程訪問權限,防火墻開放3306端口,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01
MySQL性能監(jiān)控軟件Nagios的安裝及配置教程
這篇文章主要介紹了MySQL性能監(jiān)控軟件Nagios的安裝及配置教程,這里以CentOS操作系統(tǒng)為環(huán)境進行演示,需要的朋友可以參考下2015-12-12
mysql啟動失敗之mysql服務無法啟動(服務沒有報告任何錯誤)的解決方法
作為一名程序猿,必不可少的便是和mysql打交道,那當mysql故障,服務無法啟動時該怎么解決呢,下面這篇文章主要給大家介紹了關于mysql啟動失敗之mysql服務無法啟動,服務沒有報告任何錯誤的解決方法,需要的朋友可以參考下2022-05-05

