天天看點

通過bat檔案 進行mysql 連接配接 或者 操作涉及 密碼的,如果密碼 中有 % 号的話要特殊處理

比如我想在bat檔案中進行一個資料庫的連接配接 或者進行一個資料庫中的 資料 導入或者導出(mysqldump) 這樣子都會用到資料庫密碼,

假如這個資料庫的密碼 中又有 % 的話就要特殊轉義一下才行執行這個bat檔案了,不然 這個密碼其實就是錯誤的,即沒法操作到資料庫的了,因為Windows的指令行解釋器 在解釋 % 時 是會把 % 看出一個特殊的字元,即轉義的字元,即有特殊含義的,是以假如密碼中有%  那要按照 2個% 轉義成一個 %,4個%轉義成2個% 這樣子規則來重新修改一下密碼才行,不然 最後密碼會被轉義成錯誤的密碼進而沒辦法正常連接配接資料庫或者操作資料庫。

如:

@echo off

if "%1" == "" (goto input_data) ELSE (goto input_var)

:input_data

set /p var=INPUT DATE(fmt:yyyyMMddHHmm):

goto start

:input_var

set /a var=%1

goto start

:start

cd  %cd%

md .... o-saveTKcard\%var%

mysql -P3302 -uroot -pdst72j$mq)c%%8 -h61.160.245.119 -N -s -e"SET SESSION group_concat_max_len = 99999999;SELECT CONCAT('mysqldump -h61.160.245.119 -P3302 -uroot

-pdst72j$mq)c%%%%8 --opt -n TKCard_cn_cn_db210060000 ',GROUP_CONCAT(t.TABLE_NAME SEPARATOR  ' '),' >') FROM information_schema.TABLES t WHERE t.TABLE_SCHEMA =

'TKCard_cn_cn_db210060000' AND (t.TABLE_NAME LIKE 'dict_%%')  AND t.TABLE_NAME NOT IN('dict_keyvalue','dict_server','dict_operator_config');" > tkcard_dict.bat

for /f "delims=] tokens=1" %%a in (tkcard_dict.bat) do echo %%a .... o-saveTKcard\%var% kcard_dict.sql >tkcard_dict.bat

call tkcard_dict.bat

上邊 2處密碼 原始密碼皆為  dst72j$mq)c%8 ,即原始密碼中含有一個%,但是我在通過bat檔案編寫時必須這樣,即第一處編寫時必須在%前多加1個%,第二處在%前多加3個%,這樣子 bat檔案在執行時通過轉義才會把2處的密碼轉義成正确的原始密碼:僅有一個% 的dst72j$mq)c%8