実現したいこと
- sqlcmdでデータベースから抽出した情報をCSVとして出力したい
前提
A5:SQLで買い物情報の管理をしています。
SQLを扱えない人用に一覧表を作成できるバッチファイルを作成中です。
作成したバッチファイルが、「指定されたファイルが見つかりません」と表示されてCSVが作成されません。
不足しているコードがあると認識しています。ご指摘いただけますと幸いです。
発生している問題・エラーメッセージ
’sql.sql' '指定されたファイルが見つかりません’
該当のソースコード
bat
1@echo off 2 3echo 処理開始 4 5set /p YYYYYMMDDFROM='開始日を入力してください' 6set /p YYYYYMMDDTO='終了日を入力してください' 7 8set local enabledelayedexpansion 9 10echo 処理を始めます 11echo--------------- 12 13pause 14 15sqlcmd -S [server] -d [db] -U [user] -P [pass] -i sql.sql -v target date from=!YYYYMMDDFROM! target date to=!YYYYMMDDTO! -b -s -W -o .\%CSV\%YYYYMMDD%.csv 16 17endlocal
SQL
1set nocount on 2--*電化製品 3SELECT 4 M.date AS 日付 5 M.count(*) AS 件数 6FROM 7 Main_doc M 8INNER JOIN 9 Sub_doc S 10 ON M.id = S.id 11 AND M.sub_id = S.sub_id 12 AND M.date = S.date 13WHERE date = BETWEEN $(target date from) AND BETWEEN $(target date to) 14 AND M.id = 1 15 AND M.sub_id = 1 16 AND S.user_code = U102345; 17GROUP BY 18 M.date 19--*食料品 20SELECT 21 M.date AS 日付 22 M.count(*) AS 件数 23FROM 24 Main_doc M 25INNER JOIN 26 Sub_doc S 27 ON M.id = S.id 28 AND M.sub_id = S.sub_id 29 AND M.date = S.date 30WHERE date = BETWEEN $(target date from) AND BETWEEN $(target date to) 31 AND M.id = 2 32 AND M.sub_id = 2 33 AND S.user_code = U102345; 34GROUP BY 35 M.date; 36set nocount off
試したこと
・sql.sqlファイルをsql.txtに修正して実行。
結果:変化なし
・-i sql.sql を-i .%sql.sql %に修正して実行。
結果:変化なし
sqlファイル、txtファイル共にバッチファイルと同じフォルダ内に設置しています。
SQLは元々情報抽出用に書いたものを、一部バッチファイル用に修正しました。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2023/09/09 13:21