[解決済み] WHERE句の参照エイリアス(SELECTで計算)。
2022-04-27 07:59:20
質問
SELECT (InvoiceTotal - PaymentTotal - CreditTotal) AS BalanceDue
FROM Invoices
WHERE BalanceDue > 0 --error
計算された値
BalanceDue
選択されたカラムのリストで変数として設定されているものは、そのカラムに対応する
WHERE
節があります。
できる方法はありますか?この関連する質問で ( MySQLのSelectステートメントでWhere句に変数を使用する )、答えは、実は、ダメで、計算を書き出すだけのような気がします( と は、クエリ内でその計算を行う)を2回行い、いずれも満足のいくものではありません。
どうすればいいですか?
SELECTは2番目に評価される最後の節なので、ORDER BY以外ではエイリアスを参照できません。2つの回避策があります。
SELECT BalanceDue FROM (
SELECT (InvoiceTotal - PaymentTotal - CreditTotal) AS BalanceDue
FROM Invoices
) AS x
WHERE BalanceDue > 0;
または、式を繰り返すだけです。
SELECT (InvoiceTotal - PaymentTotal - CreditTotal) AS BalanceDue
FROM Invoices
WHERE (InvoiceTotal - PaymentTotal - CreditTotal) > 0;
私は後者がいいと思います。式が非常に複雑な場合(あるいは計算にコストがかかる場合)、代わりに計算カラム(およびおそらくパーシステッド)を考慮する必要があります。
追記 あなたの心配は杞憂に終わったようです。少なくともこの単純な例では、SQL Serverは賢いので、たとえ2回参照したとしても、計算は1回しか実行しません。計画を比較してみてください。もし、もっと複雑なケースで式が複数回評価されるようなことがあれば、より複雑なクエリと計画を投稿してください。
以下は5つのクエリの例で、すべて全く同じ実行プランになります。
SELECT LEN(name) + column_id AS x
FROM sys.all_columns
WHERE LEN(name) + column_id > 30;
SELECT x FROM (
SELECT LEN(name) + column_id AS x
FROM sys.all_columns
) AS x
WHERE x > 30;
SELECT LEN(name) + column_id AS x
FROM sys.all_columns
WHERE column_id + LEN(name) > 30;
SELECT name, column_id, x FROM (
SELECT name, column_id, LEN(name) + column_id AS x
FROM sys.all_columns
) AS x
WHERE x > 30;
SELECT name, column_id, x FROM (
SELECT name, column_id, LEN(name) + column_id AS x
FROM sys.all_columns
) AS x
WHERE LEN(name) + column_id > 30;
5つのクエリすべてに対する結果プラン。
関連
-
解決策:java.sql.SQLException: ユーザー ''@'localhost'' (パスワード: YES を使用) のアクセスが拒否されました。
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] 各GROUP BYグループの最初の行を選択しますか?
-
[解決済み] SQLのSELECTでIF...THENを実行するにはどうすればよいですか?
-
[解決済み] ...値に挿入する ( SELECT ... FROM ... )
-
[解決済み] SQL Server - 挿入された行のIDを取得するための最良の方法は?
-
[解決済み] SQLのIN句をパラメータ化する
-
[解決済み] INNER JOIN ON vs WHERE句
-
[解決済み] SQL JOIN - WHERE句とON句の比較
-
[解決済み] MySql でクエリ実行時に only_full_group_by に関連するエラーが発生する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
解決策:java.sql.SQLException: ユーザー ''@'localhost'' (パスワード: YES を使用) のアクセスが拒否されました。
-
[解決済み] SQL ServerでJOINを使用してUPDATE文を実行するにはどうすればよいですか?
-
[解決済み] SQL Server - 挿入された行のIDを取得するための最良の方法は?
-
[解決済み] SQL Serverでレコードを削除した後、IDシードをリセットする。
-
[解決済み] MySQLでFULL OUTER JOINを行うにはどうすればよいですか?
-
[解決済み] 各グループの上位1行を取得
-
[解決済み] NOT IN vs NOT EXISTS
-
[解決済み] SQL ServerでINSERT INTOとしてデータをエクスポートする
-
[解決済み] "ON UPDATE CASCADE "を使用する場合について
-
[解決済み] Entity Framework VS LINQ to SQL VS ADO.NETでストアドプロシージャを使う?[クローズド]