質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
A5:SQL Mk-2

A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

Q&A

解決済

2回答

1877閲覧

自作したバッチファイルを実行すると「指定されたファイルが見つかりません」と表示される

rio447

総合スコア4

A5:SQL Mk-2

A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

0グッド

0クリップ

投稿2023/09/07 13:57

編集2023/09/09 13:29

実現したいこと

  • 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は元々情報抽出用に書いたものを、一部バッチファイル用に修正しました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

次のようなやり方はどうでしょう。

  • sql.sqlファイルを絶対パスで指定する (実際にファイルのあるディレクトリで)
sqlcmd ... -i c:\foo\bar\baz\sql.sql ...
  • sql.sql がバッチファイルと同じディレクトリなら次のようにも書けます
sqlcmd ... -i %~dp0\sql.sql ...
  • ファイルを絶対パスで指定する代わりに、カレントディレクトリをバッチファイルがあるディレクトリに移動する手もあります (バッチファイルの先頭で cd します)
@echo off cd %~dp0 (以下は変更なし)

個人的には、今回のケースだと2番目がお勧めなのかなと思います。
%~dp0 については、検索すればいろいろ説明が見つかると思います。
https://pentan.info/server/windows/cmd/dp0.html とか。

投稿2023/09/08 12:46

bsdfan

総合スコア4601

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rio447

2023/09/09 13:21

回答ありがとうございました。 絶対パスで実行したところ、「指定されたパスが見つかりません」と表示がありました。 sql.sqlをバッチファイルと同じディレクトリに移動して、コードを修正しても「指定されたパスが見つかりません」と表示がありました。 「%~dp0」をbatに設置して実行したところ、無事動作を確認しました。
guest

0

まずはそのファイルをフルパスで記述して実行できるか確認してみたらどうでしょう
それができのであれば、あとはファイルのパスの問題であるってことがわかります

投稿2023/09/07 14:35

y_waiwai

総合スコア87802

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rio447

2023/09/09 13:13

回答ありがとうございました。 フルパスで実行したところ、「指定されたパスが見つかりません」と表示がありました。 「cd %~dp0」をbat先頭に入力したところ、無事動作を確認できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問