94

SQLをTeradataからSQLServerに変換しています

Teradataでは、次の形式になります

SELECT col1, col2
FROM table1
INTO @variable1, @variable2

SQL Serverで、私は見つけました

SET @variable1 = (
SELECT col1 
FROM table1
);

これにより、ステートメントごとに1つの列/変数のみが許可されます。単一のSELECTステートメントを使用して2つ以上の変数を割り当てる方法は?

4

2 に答える 2

193
SELECT @variable1 = col1, @variable2 = col2
FROM table1
于 2009-08-27T12:32:56.690 に答える
41
SELECT @var = col1,
       @var2 = col2
FROM   Table

SET/SELECTに関するいくつかの興味深い情報があります

  • SETは変数割り当てのANSI標準ですが、SELECTはそうではありません。
  • SETは一度に1つの変数のみを割り当てることができ、SELECTは一度に複数の割り当てを行うことができます。
  • クエリから割り当てる場合、SETはスカラー値のみを割り当てることができます。クエリが複数の値/行を返す場合、SETはエラーを発生させます。SELECTは、値の1つを変数に割り当て、複数の値が返されたという事実を非表示にします(したがって、他の場所で問題が発生した理由がわからない可能性があります。そのトラブルシューティングを楽しんでください)。
  • 値が返されない場合にクエリから割り当てる場合、SETはNULLを割り当てます。ここで、SELECTは割り当てをまったく行いません(したがって、変数は以前の値から変更されません)。
  • 速度の違いに関しては、SETとSELECTの間に直接的な違いはありません。ただし、1回のショットで複数の割り当てを行うSELECTの機能により、SETよりも速度がわずかに向上します。
于 2009-08-27T12:33:56.643 に答える