3

バッチファイルのスクリプトは初めてです。

私が欲しいのは、SQLファイルを呼び出して結果をテキストファイルに保存するバッチファイルを作成することだけです。

誰かが私を助けてくれますか、あなたの助けは大歓迎です、

このようなファイルを作成する必要があるのはこれが初めてです。

4

3 に答える 3

8

バッチファイルの使用:

これを保存して実行します。

@echo off
sqlplus -s -l user/pass@yourdb @yoursql.sql>your_log.log

psは、SQLスクリプトの最後の行があることを確認してください。そうしexit;ないと、バッチファイルがハングします。

于 2013-01-12T16:55:55.897 に答える
3
sqlcmd -S sqlservername -i yoursqlfile.sql -U username -P password -o outputfile.txt
于 2013-01-12T14:20:13.470 に答える
0

より高度なランチャーを作成して試してみました(最新バージョンはhttp://www.unix.com/windows-and-dos-issues-and-discussions/256021-windowss-batch-launcher-oracle-にあります) sql-linux-sh-scripts-available-here.html

とにかくコードは次のとおりです。

launcher.cmd

@ECHO OFF

rem Script Launcher by Fr3dY v1.4
rem ##############################
rem Version History:
rem 1.4 - Misc. fixes
rem 1.3 - Merged with 'server launcher', now accepts both SQL and SHELL SCRIPTS
rem 1.2 - Interactive prompt to show the file on screen
rem 1.1 - No need to add 'quit;' or 'exit;' in the .sql file anymore
rem       Fixed sqlplus waiting for username/password if the first attempt was unsuccessful
rem       Log file is generated automatically, including date and time in name
rem       Misc. fixes
rem 1.0 - Initial Version

:MAIN
::Path of PLINK
set PLINK="C:\Program Files (x86)\PuTTY\plink.exe"
::List with TNS NAMES
set dbservers=launcher-databases.txt
::List with LINUX SERVERS
set linuxservers=launcher-servers.txt

set dt=%DATE:~6,4%_%DATE:~3,2%_%DATE:~0,2%__%TIME:~0,2%_%TIME:~3,2%_%TIME:~6,2%
set dt=%dt: =0%

echo Choose launcher mode:
echo 1) Database scripts (.sql files)
echo 2) Shell scripts (.sh files)
set /p launchermode="Insert value: "
echo.

if %launchermode%==1 (
  set extension=sql
  set servers=%dbservers%
  set mode=DB
) else (
    if %launchermode%==2 (
      set extension=sh
      set servers=%linuxservers%
      set mode=OS
    ) else (echo "Incorrect value, exiting..." & goto :END)
)    

if exist %servers% (
  goto :LISTFILES
) else echo FILE %servers% NOT FOUND, ABORTING & goto :END


:LISTFILES
echo Listing *.%extension% files...
echo.
dir /b *.%extension%
echo.

set /p file=Name of the file to be launched (without extension)? 

if exist %file%.%extension% (
  goto :CONFIRMSHOW
) else echo FILE %file%.%extension% NOT FOUND, ABORTING & goto :END


:CONFIRMSHOW
echo.
set /p confirm=Show the script %file%.%extension% on screen now? 
if %confirm%==y (
  goto :SHOWSCRIPT
  ) else goto :CONFIRMEXEC
echo.

:SHOWSCRIPT
echo.
echo Content of %file%.%extension%
echo ######################
type %file%.%extension%
echo.
echo ######################
echo.

:CONFIRMEXEC
set /p confirm=Are you sure you want to execute this script? 
if %confirm%==y (
  set /p user=%mode% username?  
  goto :HInput
  ) else echo ABORTED & goto :END
echo.
echo Output saved to %file%_%dt%.log
echo.
Goto :END

:HInput
::Hidden.cmd
::Tom Lavedas, 02/05/2013, 02/20/2013
::Carlos, 02/22/2013
::https://groups.google.com/forum/#!topic/alt.msdos.batch.nt/f7mb_f99lYI
::Version 3.0     
SetLocal DisableDelayedExpansion
echo.
Echo Enter password:
Set "Line="
Rem Save 0x08 character in BS variable
For /F %%# In (
'"Prompt;$H&For %%# in (1) Do Rem"'
) Do Set "BS=%%#"

:HILoop
Set "Key="
For /F "delims=" %%# In (
'Xcopy /L /W "%~f0" "%~f0" 2^>Nul'
) Do If Not Defined Key Set "Key=%%#"
Set "Key=%Key:~-1%"
SetLocal EnableDelayedExpansion
If Not Defined Key echo. & Goto :HIEnd
If %BS%==^%Key% (Set /P "=%BS% %BS%" <Nul
Set "Key="
If Defined Line Set "Line=!Line:~0,-1!"
) Else Set /P "=*" <Nul
If Not Defined Line (EndLocal &Set "Line=%Key%"
) Else For /F delims^=^ eol^= %%# In (
"!Line!") Do EndLocal &Set "Line=%%#%Key%"
Goto :HILoop

:HIEnd
if %launchermode%==1 (
  goto :EXECDB
) else goto :EXECLINUX

:EXECDB
FOR /f %%A IN (%servers%) DO CALL ECHO DATABASE: %%A & ECHO DATABASE: %%A >> %file%_%dt%.log & sqlplus -S -L %user%/!Line!@%%A < %file%.%extension% >> %file%_%dt%.log
goto :END

:EXECLINUX
FOR /f %%A IN (%servers%) DO CALL ECHO SERVER: %%A & ECHO SERVER: %%A >> %file%_%dt%.log & echo y | %PLINK% %user%@%%A -pw !Line! "exit" & %PLINK% %user%@%%A -pw !Line! -batch -m %file%.%extension% >> %file%_%dt%.log & echo. >> %file%_%dt%.log
goto :END

:END
pause
于 2015-03-10T11:20:05.460 に答える