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

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

ただいまの
回答率

91.01%

  • SQL Server

    509questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

  • Transact-SQL

    12questions

    Transact-SQLはSybase ASEとMIcrosoft SQLサーバで対応されているSQLの機能拡張版です。

T-SQL:カーソル文で2行分の結果を変数に格納する方法

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 169

dera

score 9

初めまして。T-SQLのカーソル文について質問です。

T-SQLのカーソル文はSELECTした結果を1行ずつ取り出し、
対応した変数に格納することができると思いますが、
SELECTした結果が2行あり2行分のデータを変数に格納するには
どうすればよろしいでしょうか?

例を示しますが、
FETCH NEXT~のところからINTOで変数にセットしていますが、
これだと1行分のデータを変数にセットして1行ずつ処理をしていると
考えます。そうではなくて、
ここで2行分入れてからそれを基に判定処理を作成したいと考えております。

SQL-Serverは2014年のものを使用しております。

皆様の力をお貸しください。よろしくお願いいたします。

--カーソルの値を取得する変数宣言
DECLARE @W_COL1 varchar(50)
DECLARE @W_COL2 decimal(18,0)

--カーソル定義
DECLARE CUR_AAA CURSOR FOR
    SELECT COL1
          ,COL2
    FROM   TAB_A
    WHERE  TAB_A.COL1 = <条件値>

--カーソルオープン
OPEN CUR_AAA;

--最初の1行目を取得して変数へ値をセット
FETCH NEXT FROM CUR_AAA
INTO @W_COL1,@W_COL2;

--データの行数分ループ処理を実行する
WHILE @@FETCH_STATUS = 0
BEGIN

    -- ========= ループ内の実際の処理 ここから===

    INSERT INTO TAB_B
    VALUES (
        @W_COL1
       ,@W_COL2
    )

    -- ========= ループ内の実際の処理 ここまで===


    --次の行のデータを取得して変数へ値をセット
    FETCH NEXT FROM CUR_AAA
    INTO @W_COL1,@W_COL2;

END

--カーソルを閉じる
CLOSE CUR_AAA;
DEALLOCATE CUR_AAA;
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

fetch nextを2回すればいいと思うのですがダメでしたか?

--カーソルの値を取得する変数宣言1
DECLARE @W1_COL1 varchar(50)
DECLARE @W1_COL2 decimal(18,0)
--カーソルの値を取得する変数宣言2
DECLARE @W2_COL1 varchar(50)
DECLARE @W2_COL2 decimal(18,0)

-- ~~~~省略~~~~

--最初の1行目を取得して変数へ値をセット
FETCH NEXT FROM CUR_AAA
INTO @W1_COL1,@W1_COL2;
--次を取得して変数へ値をセット
FETCH NEXT FROM CUR_AAA
INTO @W2_COL1,@W2_COL2;

-- ~~~省略~~~~

直接関係ありませんがカーソルのselect文にorderbyが無いのは良くないです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/15 10:35

    FETCH NEXTを2回試したところ、
    2行分の値を格納することができました。ありがとうございます。
    ただ、カーソルのSELECT文にORDER BYがないといけない理由が考えてもわかりませんでした。どういった時に影響を及ぼすのでしょうか?

    キャンセル

  • 2018/01/15 10:59

    orderbyが指定されていれば「次はこれです」とデータベースが論理的に説明できます。
    orderbyがない現状だとsqlserverのオプティマイザが自動選択するindexに結果が左右され
    「思った通りの順番でデータが来ない」可能性があります。データベースは開発者の心情を汲み取っては
    くれないので並んでほしい順番があるのならorderbyは必須です。
    orderbyを指定していない場合「並び順はどうでもいいですよ」とデータベースに伝えているいうことです。

    キャンセル

  • 2018/01/15 11:06

    そういうことでしたか。確かに、ORDER BY句で指定していないと、自分が想定したパターンと異なることが考えられますね・・。とても勉強になりました。ありがとうございます!

    キャンセル

  • 2018/01/15 11:16

    私もSQLServer使ってますので頑張りましょう。b
    ついでですがカーソルはデフォルトではグローバルなので
    DECLARE CUR_AAA CURSOR LOCAL FOR
    にしてカーソルをローカルにするといいと思います(外からカーソルを見ない場合はですが)。
    また私はやったことありませんがnextしかしない場合
    DECLARE CUR_AAA CURSOR LOCAL FAST_FORWARD FOR
    とするとパフォーマンスが上がるそうです。調べてみるといいと思います。

    キャンセル

  • 2018/01/15 13:04

    そういったものもあるんですね。
    パフォーマンスまでは全然考慮していませんでした。
    色々と教えていただき、ありがとうございます。
    まだまだ触り始めたばかりなので、いろいろ試して頑張ってみます!

    キャンセル

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

  • ただいまの回答率 91.01%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • SQL Server

    509questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

  • Transact-SQL

    12questions

    Transact-SQLはSybase ASEとMIcrosoft SQLサーバで対応されているSQLの機能拡張版です。