7
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Realmについて知る①

Last updated at Posted at 2021-12-12

備忘録
#はじめに
Realmについて学習するために書き、前提としてiOSの利用で話を進めていく。

この本と各サイトを参考にして学んでいく。

#そもそもデータベース(DB)とは?
色んなデータを格納しているデータの集合体

基本的にアプリを完全に終了した場合、デメモリ上からータは消えてしまう。

例えば、TODOアプリで考えてみると、アプリ起動中に追加したタスクをDBに保存することによってアプリ内にタスクというデータを保存する事が可能になる。

また過去に保存したタスクを効率よく検索できる機能もDBには備わっている。

#iOSで用意されている保存方法
###・UserDefaults
キーと保存したい値のペアを簡単にアプリ内で永続化することができるキーバリュー型のDB

plist形式(XMLファイル)で保存されている。
.plistってなんやねん?

コードで書くとこんな感じ↓

import Foundation

// キーバリュー型のDB
let userDefaults = UserDefaults.standard

// キーと値
var key = "hogeKey"
var text = "hoge"

// 保存
userDefaults.set(text, forKey: key)

// 取得
var savedText = userDefaults.string(forKey: key) ?? ""

// 削除
userDefaults.removeObject(forKey: key)

#####○メリット

  • 様々な型を保存・取得できるAPIが複数用意されている
  • 純正のフレームワークなので簡単に使うことができる
  • 学習コストが低い

#####○デメリット

  • 自前で用意した型は保存できなくないが、少し工夫が必要
  • 使用するには全てのデータをメモリに展開する必要があり、大量にデータを保存しているとメモリの負担が大きいため大量のデータ保存には不向き
  • 検索機能はない

###・SQLite
アプリでの利用を想定されて作られたDBで非常に軽量。

詳しく書くと、SQLiteはRDBMS(リレーショナルDB管理システム)の一つであり、SQL(DB言語)を使用して操作する。

#####○メリット

  • 高速に動作し、様々な検索機能が備わっている
  • オープンソース
  • 他のDBでも使われているSQLを使用して操作可能

#####○デメリット

  • SQLを書けないと操作できない
  • 非同期処理や同時書き込みに対応するには、自分で制御・管理しなくてはならない

#####※DBMS(DB管理システム)とは
現実で例えると、DBが図書館、DBMSはそこで働く職員、SQLは日本語や英語など。

職員に「この本を追加してほしい」と頼めば新たに追加してくれるし、「この本はどこにある?」と伝えれば自分で探すよりも効率よく読みたい本を見つける事ができる。

下記のサイトを参考にすると、DBというのはデータベースファイル(データが書き込まれているファイル) + DBMSの2つで構成されていて、このデータベースファイルにデータを書き込んだり読み込んだりしているのがDBMSだそう↓

DBとDBMS(DB管理システム)の違い

#####※RDBMS(リレーショナルDB管理システム)とは
DBMSには階層型やネットワーク型といった様々な形式があり、その中でも主流なのが関係(リレーショナル)型

大きな特徴として、表(テーブル)行(レコード)列(カラム)で構成されている。

・表(テーブル)
複数のデータ(レコード)を収容する場所。
db_関係型_sample.png

・行(レコード)
1件分のデータ。
レコード.png

・列(カラム)
データを構成する各項目。
フィールド.png

#Realmとは
モバイル向けに設計されたDB。

大きな特徴としては、Swiftのクラスが、Realmでのテーブル定義となり、そのクラスにRealm特有のObjectクラスを継承することによって、Realmでのテーブルとなる。

import RealmSwift

// Realmのテーブル定義
class Hoge: Object {
  // DBで扱いたい値をプロパティで定義する
  @objc dynamic var hoge: String = "hogehoge"
  @objc dynamic var fuga: Bool = false
}

SQLiteでは、SQLでテーブル定義しなくてはならないし、それらをSwiftのオブジェクトとして扱うためのクラスも定義する必要がある。

しかし、RealmではSwiftでクラスを作れば、それがテーブルとなる。

#####○メリット
SQLiteや純正のCore Dataよりも高速らしい
・クラス定義がそのままテーブル定義となる
・自前の型も簡単に保存可能
・プライマリキーが指定できる

#####○デメリット
・オートインクリメントを設定できない
取得するデータの上限を設定するlimitがない

#####※プライマリキー(主キー)とは
テーブル内でレコードを一意(重複しない)に識別することができるように指定される項目(カラム)

現実で例えると、ある学校の1クラスがテーブル、生徒がレコードで出席番号が主キーとなる。

イメージはこんな感じ↓
スクリーンショット 2021-12-12 7.46.15.png
「出席番号」、「名前」、「性別」という3つの項目がカラムとなる。

どれでも主キーにできる訳ではなく下記の2つの条件を満たしてなければいけない。

1.一意になっていること
2.nil(空)ではないこと

以上のカラムが主キーとして指定できる。

先ほどのテーブルで言うと、「出席番号」は一意であり、必ず生徒が居れば番号が振り分けられるため主キーに適している。

#####※オートインクリメントとは
指定したカラムに対してデータが追加されると、自動的に1ずつ値を付与してくれる機能

基本的にオートインクリメントは主キーと併用して使われる。

#おわりに
②はRealmの読み書き・削除なんかをまとめたい。

後はマイグレーションの事とか。

何か間違っていることや疑問があればコメントして下さると有り難いです。

7
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?