アプリ版:「スタンプのみでお礼する」機能のリリースについて

ExcelからSQL Serverの外部取り込みを行う際に
VBAの条件文の1部にWHERE(JOBTBL.BATCHID Like '12%')と書き
実行すると12から始まるデータの取得が正常に行われます。

実際には'12%'の箇所に当日日付を取得するようなものを書きたいので
変数T_DAY=format(Now,"mmdd")を入れて
WHERE(JOBTBL.BATCHID Like 'T_DAY%')で実行すると
エラーは出ませんが結果が表示されません。

変数を使用することは出来ないのでしょうか?
その場合、当日日付4桁から始まる列を含むテーブルを取得したい場合
どのようにすればよいでしょうか?
ご教授ください。

A 回答 (1件)

"WHERE(JOBTBL.BATCHID Like '12%')"



も変数に入っているものですよね?

strSQL = "(略)..WHERE(JOBTBL.BATCHID Like '12%')"

これなら SQL Server 側で認識されるSQLは
(書くまでもないと思いますが)

(略)..WHERE(JOBTBL.BATCHID Like '12%')

になります。

では、質問者様の書かれたSQLではどうでしょうか?

T_DAY=format(Now,"mmdd")
strSQL = "(略)..WHERE(JOBTBL.BATCHID Like 'T_DAY%')"

SQL Server側で認識されるSQLは

(略)..WHERE(JOBTBL.BATCHID Like 'T_DAY%')

です。

つまり、『BATCHID が文字列「T_DAY」で始まるもの』となってしまいます。

VBA側の変数T_DAYの内容で渡したいわけですから、以下のようにします。

strSQL = "(略)..WHERE(JOBTBL.BATCHID Like '" & T_DAY & "%')"

これなら、T_DAY が 1202 だとしたら、SQL Server 側で認識されるSQLは

(略)..WHERE(JOBTBL.BATCHID Like '1202%')

となります。

この回答では簡便な方法で書きましたが、上記の方法は、本来は、プレースホルダによるパラメータバインドを使うべきです。

手入力の値ではないと言う事で、大丈夫だとは思いますが、SQLインジェクションを起こし易いセキュリティレスな方法なので好ましくないです。
一応、MSDNの例が載っているところをリンクしておきます。

SqlCommand.Prepare メソッド
http://msdn.microsoft.com/ja-jp/library/system.d …
    • good
    • 0
この回答へのお礼

うまくいきました!!
ありがとうございます。

お礼日時:2010/12/02 21:42

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています


このQ&Aを見た人がよく見るQ&A