2025-08-14 18:10:10 +08:00
|
|
|
@echo off
|
|
|
|
setlocal enabledelayedexpansion
|
2025-08-17 02:18:33 +08:00
|
|
|
chcp 65001 >nul
|
2025-08-17 04:31:42 +08:00
|
|
|
title Import Data Into MySQL
|
2025-08-14 18:10:10 +08:00
|
|
|
|
2025-08-19 19:43:29 +08:00
|
|
|
set "SCRIPT_PATH=%~dp0"
|
|
|
|
|
2025-08-14 18:10:10 +08:00
|
|
|
set MYSQL_HOST=127.0.0.1
|
|
|
|
set MYSQL_PORT=33306
|
|
|
|
set MYSQL_USER=root
|
|
|
|
set MYSQL_PASS=Root@2025
|
2025-08-17 04:31:42 +08:00
|
|
|
set MYSQL_EXE=mysql.exe
|
2025-08-14 18:10:10 +08:00
|
|
|
set SCRIPTS_DIR=script
|
|
|
|
|
2025-08-17 04:31:42 +08:00
|
|
|
where %MYSQL_EXE% >nul 2>&1
|
|
|
|
if %errorLevel% neq 0 (
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_error Error: mysql.exe not found in PATH
|
|
|
|
pause && exit /b 1
|
|
|
|
)
|
|
|
|
|
|
|
|
where rar.exe >nul 2>&1
|
|
|
|
if %errorLevel% neq 0 (
|
|
|
|
call :log_error Error: rar.exe not found in PATH
|
|
|
|
call :log_error Please install WinRAR or add it to PATH
|
|
|
|
pause && exit /b 1
|
2025-08-17 04:31:42 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
if not exist "%SCRIPTS_DIR%" (
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_error Error: Scripts directory not found at %SCRIPTS_DIR%
|
|
|
|
pause && exit /b 1
|
2025-08-17 04:31:42 +08:00
|
|
|
)
|
|
|
|
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_info Testing MySQL connection...
|
2025-08-17 04:31:42 +08:00
|
|
|
%MYSQL_EXE% -h %MYSQL_HOST% -P %MYSQL_PORT% -u %MYSQL_USER% -p%MYSQL_PASS% -e "SELECT 1" >nul 2>&1
|
|
|
|
if %errorLevel% neq 0 (
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_error Failed to connect to MySQL server
|
|
|
|
call :log_error Please verify your connection parameters:
|
|
|
|
call :log_error Host: %MYSQL_HOST%
|
|
|
|
call :log_error Port: %MYSQL_PORT%
|
|
|
|
call :log_error User: %MYSQL_USER%
|
|
|
|
pause && exit /b 1
|
2025-08-17 04:31:42 +08:00
|
|
|
)
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_info MySQL connection successful. Starting import process...
|
2025-08-17 04:31:42 +08:00
|
|
|
|
2025-08-19 19:43:29 +08:00
|
|
|
call :GetDate
|
|
|
|
set CURRENT_DATE=%FormattedDate%
|
|
|
|
call :log_info CURRENT_DATE: %CURRENT_DATE%
|
|
|
|
set TEMP_SQL_DIR=%temp%\%CURRENT_DATE%
|
|
|
|
if not exist "!TEMP_SQL_DIR!" mkdir "!TEMP_SQL_DIR!"
|
|
|
|
call :log_info TEMP_SQL_DIR: %TEMP_SQL_DIR%
|
2025-08-17 04:31:42 +08:00
|
|
|
|
2025-08-14 18:10:10 +08:00
|
|
|
for /d %%D in ("%SCRIPTS_DIR%\*") do (
|
2025-08-19 19:43:29 +08:00
|
|
|
set "folder=%%~nxD"
|
|
|
|
call :log_info Processing database: !folder!
|
|
|
|
|
|
|
|
call :log_info Creating database '!folder!' if not exists...
|
|
|
|
%MYSQL_EXE% -h %MYSQL_HOST% -P %MYSQL_PORT% -u %MYSQL_USER% -p%MYSQL_PASS% -e "CREATE DATABASE IF NOT EXISTS `!folder!`;"
|
|
|
|
|
|
|
|
if %errorLevel% neq 0 (
|
|
|
|
call :log_error Failed to create database '!folder!'
|
|
|
|
pause && exit /b 1
|
|
|
|
)
|
|
|
|
|
|
|
|
for %%F in ("%%D\*.sql") do (
|
|
|
|
call :log_info Importing file: %%~nxF into database !folder!
|
|
|
|
%MYSQL_EXE% -h %MYSQL_HOST% -P %MYSQL_PORT% -u %MYSQL_USER% -p%MYSQL_PASS% !folder! < "%%F"
|
2025-08-17 04:31:42 +08:00
|
|
|
|
|
|
|
if %errorLevel% neq 0 (
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_error Failed to import file %%~nxF
|
|
|
|
pause && exit /b 1
|
2025-08-17 04:31:42 +08:00
|
|
|
)
|
2025-08-14 18:10:10 +08:00
|
|
|
|
2025-08-19 19:43:29 +08:00
|
|
|
copy "%%F" "!TEMP_SQL_DIR!\" >nul
|
|
|
|
del "%%F" >nul
|
|
|
|
)
|
|
|
|
call :log_info Completed processing database: !folder!
|
|
|
|
call :log_info ----------------------------------------
|
2025-08-14 18:10:10 +08:00
|
|
|
)
|
|
|
|
|
2025-08-19 19:43:29 +08:00
|
|
|
call :log_info All SQL files imported successfully!
|
|
|
|
call :rar
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:log_info
|
|
|
|
call :GetFormattedTime
|
|
|
|
echo [%FormattedTime%] - [INFO] - %*
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:log_warn
|
|
|
|
call :GetFormattedTime
|
|
|
|
echo [%FormattedTime%] - [WARN] - %*
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:log_error
|
|
|
|
call :GetFormattedTime
|
|
|
|
echo [%FormattedTime%] - [ERROR] - %*
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:rar
|
|
|
|
call :RandomStr 16 RAND_NAME
|
|
|
|
set TARGET_DIR=%temp%\!CURRENT_DATE!
|
|
|
|
if not exist "!TARGET_DIR!" mkdir "!TARGET_DIR!"
|
|
|
|
|
|
|
|
call :log_info Creating encrypted archive...
|
|
|
|
rar a -ep1 -hp"Password#!CURRENT_DATE!" "!TARGET_DIR!\!RAND_NAME!.rar" "!TEMP_SQL_DIR!\*" >nul
|
|
|
|
|
|
|
|
if %errorLevel% neq 0 (
|
|
|
|
call :log_error Error: Failed to create encrypted archive
|
|
|
|
pause
|
|
|
|
exit /b 1
|
|
|
|
)
|
|
|
|
|
|
|
|
if not exist "%SCRIPT_PATH%/patch/!CURRENT_DATE!" mkdir "%SCRIPT_PATH%/patch/!CURRENT_DATE!"
|
|
|
|
call :log_info TEMP_SQL_DIR: %TEMP_SQL_DIR%
|
|
|
|
|
|
|
|
mv !TEMP_SQL_DIR!/*.rar "%SCRIPT_PATH%/patch/!CURRENT_DATE!"
|
|
|
|
rd /s /q "!TEMP_SQL_DIR!" 2>nul
|
|
|
|
|
|
|
|
call :log_info Encryption completed successfully!
|
|
|
|
call :log_info Archive: !TARGET_DIR!\!RAND_NAME!.rar
|
|
|
|
call :log_info Password: Password#!CURRENT_DATE!
|
|
|
|
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:RandomStr
|
|
|
|
setlocal
|
|
|
|
set "len=%~1"
|
|
|
|
set "varname=%~2"
|
|
|
|
if "!varname!"=="" set "varname=RAND_STR"
|
|
|
|
|
|
|
|
set "chars=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
|
|
|
|
set "random_str="
|
|
|
|
|
|
|
|
for /l %%i in (1,1,!len!) do (
|
|
|
|
set /a rand_index=!random! %% 62
|
|
|
|
call set "char=%%chars:~!rand_index!,1%%"
|
|
|
|
set "random_str=!random_str!!char!"
|
|
|
|
)
|
|
|
|
|
|
|
|
endlocal & set "%varname%=%random_str%"
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:Start
|
|
|
|
setlocal
|
|
|
|
set DESCRIPTION=%1
|
|
|
|
set SCRIPT_PATH=%2
|
|
|
|
set SCRIPT_FILE=%3
|
|
|
|
|
|
|
|
if exist "%SCRIPT_PATH%\%SCRIPT_FILE%" (
|
|
|
|
echo.
|
|
|
|
call :log_info Starting %DESCRIPTION%...
|
|
|
|
cd /d "%SCRIPT_PATH%"
|
|
|
|
start "%DESCRIPTION% Startup" /B cmd /c "%SCRIPT_FILE%"
|
|
|
|
if errorlevel 1 (
|
|
|
|
call :log_error %DESCRIPTION% start Failed.
|
|
|
|
pause && exit /b 1
|
|
|
|
)
|
|
|
|
) else (
|
|
|
|
call :log_error Script file not found: %SCRIPT_PATH%\%SCRIPT_FILE%
|
|
|
|
pause && exit /b 1
|
|
|
|
)
|
|
|
|
endlocal
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:GetFormattedTime
|
|
|
|
for /f "tokens=2 delims==" %%a in ('wmic OS Get localdatetime /value') do set "datetime=%%a"
|
|
|
|
set "FormattedTime=%datetime:~0,4%-%datetime:~4,2%-%datetime:~6,2% %datetime:~8,2%:%datetime:~10,2%:%datetime:~12,2%"
|
|
|
|
exit /b 0
|
|
|
|
|
|
|
|
:GetDate
|
|
|
|
for /f "tokens=2 delims==" %%a in ('wmic OS Get localdatetime /value') do set "datetime=%%a"
|
|
|
|
set "FormattedDate=%datetime:~0,4%%datetime:~4,2%%datetime:~6,2%"
|
|
|
|
exit /b 0
|