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

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

新規登録して質問してみよう
ただいま回答率
87.20%
SQL Server

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

解決済

移行におけるマルチカラムアトリビュートの解消方法について

kakutus
kakutus

総合スコア2

SQL Server

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

1回答

0評価

0クリップ

215閲覧

投稿2022/06/01 05:01

SQLアンチパターンの1つであるマルチカラムアトリビュートを解決するためにテーブルを作り直してデータを移行する場合、カーソル処理以外だとどのような移行方法がありますでしょうか。

実現したいこと

以下のテーブルAを、テーブルBに作り直すとします。

テーブルA

氏名ID住所1住所2住所3
0001A県B市C町
0002D県E郡NULL

テーブルB

氏名ID住所ID住所
00011A県
00012B市
00013C町
00021D県
00022E郡

※NULLのデータは移行しない

該当のソースコード

移行するためのSQLを実装するとき、1番最初に思い付いたのは以下のようなカーソル処理での場合分けですが、
1万件以上のデータを扱うと処理が極端に重くなってしまいます。

SQLServer

DECLARE @NameID INT; DECLARE crTriggerList CURSOR FOR SELECT [氏名ID] FROM テーブルA OPEN crTriggerList; FETCH NEXT FROM crTriggerList INTO @NameID WHILE @@FETCH_STATUS = 0 BEGIN DECLARE @Address1 INT --住所1 DECLARE @Address2 INT --住所2 DECLARE @Address3 INT --住所3 SELECT @Address1 = 住所1 ,@Address2 = 住所2 ,@Address3 = 住所3 FROM テーブルA WHERE 氏名ID = @NameID --氏名IDに紐づく住所を変数に代入 IF((@Address1 IS NOT NULL) --住所1がNULLでなければ住所IDを1として移行 BEGIN INSERT INTO テーブルB (氏名ID,住所ID,住所) SELECT 氏名ID ,'1' ,住所1 FROM テーブルA WHERE 氏名ID = @NameID END IF((@Address2 IS NOT NULL) --住所2がNULLでなければ住所IDを2として移行 BEGIN INSERT INTO テーブルB (氏名ID,住所ID,住所) SELECT 氏名ID ,'2' ,住所2 FROM テーブルA WHERE 氏名ID = @NameID END IF((@Address3 IS NOT NULL) --住所3がNULLでなければ住所IDを3として移行 BEGIN INSERT INTO テーブルB (氏名ID,住所ID,住所) SELECT 氏名ID ,'3' ,住所3 FROM テーブルA WHERE 氏名ID = @NameID END FETCH NEXT FROM crTriggerList INTO @NameID END CLOSE crTriggerList; DEALLOCATE crTriggerList;

カーソル処理を使わずにこのような移行が出来る方法がもしあるのであれば、教えていただきたいです。
よろしくお願いします。

補足情報(FW/ツールのバージョンなど)

Microsoft SQL Server Management Studio 18
Microsoft SQL Server 2019 (RTM-GDR) (KB4583458) - 15.0.2080.9 (X64) Nov 6 2020 16:50:01 Copyright (C) 2019 Microsoft Corporation Enterprise Edition (64-bit) on Windows Server 2019 Datacenter 10.0 <X64> (Build 17763: ) (Hypervisor)

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

SQL Server

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。