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

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

新規登録して質問してみよう
ただいま回答率
85.49%
Visual Basic 6.0

Microsoft Visual Basic 6.0(VB6)とはCOMプログラミングのためにMicrosoftが提供したプログラミング言語とintegrated develpment enviornment(IDE)のことです。

Q&A

解決済

2回答

348閲覧

SQLを組み立てるときselect句とそれ以外を別の変数に格納する意味は?

ku__ra__ge

総合スコア4524

Visual Basic 6.0

Microsoft Visual Basic 6.0(VB6)とはCOMプログラミングのためにMicrosoftが提供したプログラミング言語とintegrated develpment enviornment(IDE)のことです。

0グッド

0クリップ

投稿2017/10/04 12:12

非常に古い業務系システムのコードを読んでいるときに、SQLを組み立てるときselect句とそれ以外を別の変数に格納して、あとでそれを文字列結合するというコードをよく見ます。

特に意味があるとは思えませんが、これはなにか歴史的な理由があってこのような書き方になっているのでしょうか?

例えば以下のようなコードです。

Dim sSqlSelect As String Dim sSql As String sSqlSelect = "" sSqlSelect = sSqlSelect & " select " sSqlSelect = sSqlSelect & " Field1" sSqlSelect = sSqlSelect & ",Field2" sSqlSelect = sSqlSelect & ",Field3" sSql = "" sSql = sSql & " from Table " sSql = sSql & " where Field1 = '" & sField1Condition & "'" dataObject.RecordSource = sSqlSelect & sSql

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

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

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

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

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

guest

回答2

0

ベストアンサー

今でも動的SQLを作成するような場合には似たような事はやったりします。
SELECT句の部分を別変数にすることは殆ど無いですけど、条件部分などは複数の条件を組み立てた後で、不要なandやorを除去するのに別変数の方が都合が良い場合があります。

サンプルのコードについては、別変数に意味は無く、他の処理をコピーして作った名残とかじゃないでしょうか。

投稿2017/10/04 16:07

sazi

総合スコア25173

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

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

ku__ra__ge

2017/10/10 05:49

事前に取得件数を知るために`select count(*) from ...`を頻繁に使う必要があった可能性なども考えましたが、実際にはそういった処理はそんなには無かったですし、やはり何かの名残しょうね。 ありがとうございました。
guest

0

たぶん、あまり意味は無いと思いますが推測するに視認性を考慮したものかと思います。
SELECT文で大事なのは、なんていう項目をとってくるか?なので、そこだけ切り出してるのかと。
※JOIN条件とかWHERE条件とかは、どうなんだ?っていうのは触れちゃダメ

あとは、サンプルのとおり、項目名の位置がそろうことで、見やすくしているし、追加・削除がしやすい
ですね。

投稿2017/10/04 13:44

momon-ga

総合スコア4820

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問