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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Realm

RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

921閲覧

RealmSwift マイグレーションにてカラム追加後、任意の値をセットしたい

petatail

総合スコア16

Realm

RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2017/10/04 13:31

編集2017/10/14 16:49

ご教授願えませんでしょうか。

状況

  • Realmマイグレーションをテストしたいと考えております。
  • Realmにテーブルが2つ存在しております(それぞれA、Bとします)
  • Aテーブルに「goukei」カラムを追加をしたいと思っております。

テーブル内容

  • Aテーブル
idsubjectgoukei(追加するプロパティ)
0国語???
1数学???
2社会???
3物理???
4英語???
  • Bテーブル
ida_idnumber
0010
1010
2310
3010
4310
5110
6010
7410

..... numberプロパティは、scoreという名前が望ましいですね...
ややこしくて申し訳ありません。

疑問点

  1. Aテーブルに「goukei」カラムを追加して、そのカラムの値として、マイグレーション処理の中で、Bテーブルの「number」カラムの値の合計を格納したいのですが、マイグレーション処理の中で、Realmオブジェクトを生成して、Realmに格納されたデータを参照、利用することは可能なのでしょうか。
  2. Realmのテーブルに追加したカラムの順番を変える、もしくは、指定した場所への挿入が可能なのでしょうか(mysqlで例えるならAFTER処理)。デフォルトだと、末尾にカラムが追加されることを確認しました。
  3. マイグレーション中に、Aテーブル.idBテーブル.a_idを紐付け、idが一致した点数を合計して、追加したAテーブル.goukeiに格納していくことは可能なのでしょうか。

確認したこと

Realmドキュメントのマイグレーション項目を読みました。その文章の中で、issueがあがっていたので、確認したのですが、このissueが、今回私が実現しようとしていることに対してのことなのかどうか判断ができていない状況です。

補足情報

環境バージョン
xcode9.0.0
swift3.1
realm/realm-cocoav2.10.1

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

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

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

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

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

guest

回答1

0

ベストアンサー

そのIssueはあなたのやろうとしていることとは関係ありません。

Migrationのドキュメントを読まれたのならわかると思いますが、マイグレーションブロックの中では、古いスキーマのRealmと新しいスキーマのRealmの両方にアクセスできる状態が提供されています。

新しく追加したカラムに、古いデータを移行するには、ドキュメントにあるようにenumerateObjects()メソッドを用いて、古いオブジェクトにアクセスし、新しいオブジェクトにデータを設定します。

今回の例ですと、まずBテーブルのオブジェクトにアクセスして、numberカラムの値を合計したのち、Aテーブルの新しいオブジェクトのgoukeiカラムにその値を設定するだけです。

下記のコードは動作確認してないのでそのまま動くかどうかは分かりませんが、やりたことはだいたいこのような形になります。

var numbers = [Int:Int]() migration.enumerateObjects(String(describing: B.self)) { oldObject, newObject in if let oldObject = oldObject, let id = oldObject["a_id"] as? Int, let number = oldObject["number"] as? Int { if let n = numbers[id] { numbers[id] = number + n } else { numbers[id] = number } } } migration.enumerateObjects(String(describing: A.self)) { oldObject, newObject in if let oldObject = oldObject, let id = oldObject["id"] as? Int, let newObject = newObject { let goukei = numbers[id] newObject["goukei"] = goukei } }

投稿2017/10/11 17:28

編集2017/10/18 02:21
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

petatail

2017/10/11 18:04 編集

回答ありがとうございます。 回答して頂いた内容を踏まえた上で、再度質問させて下さい。 「enumerateObject()」では、Realmオブジェクト(指定したテーブル)を取得して、レコードを一つずつ取り出して、処理していくという認識で合ってますでしょうか。 具体例としては migration.enumerateObjects(ofType: Aテーブル.className()) { oldObject, newObject in } のロジックと for (index, data) in Aテーブル.enumerated() { } のロジックが、ほぼ同じようなものと考えております。
退会済みユーザー

退会済みユーザー

2017/10/11 21:03

それで合っています。
petatail

2017/10/14 16:53 編集

回答ありがとうございます。 たびたび申し訳ありませんが、テーブル内容と新規の質問(3番)を追加致しました。 よろしければ、ご教授願えませんでしょうか.... よろしくお願い致します。
petatail

2017/10/23 06:08 編集

回答ありがとうございました。 配列にid毎の合計を格納し、追加したプロパティに入れていく。 その発想は、私にはありませんでした..... 大変、参考になりました。 貴重な時間を割いて頂き、ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問