[Android] データベース SQLite の簡単作成

sqlite 02 - [Android] データベース SQLite の簡単作成
大量データの読み書き、さらに検索したい場合はデータベースが便利で、AndroidではSQLiteを使います。ここでは簡単な例を試してみます。

Android Studio 4.1
API 30



SQLite

 
最初にGoogleはデータベースとして Room を推奨しています。
Room は、SQLite 全体を対象とする抽象化レイヤを提供して、
SQLite を最大限に活用しつつ、スムーズなデータベース アクセスを可能にしてくれるそうです。

SQLiteが使えないわけではないのですが、色々面倒な操作が簡単になったRoomを使ってくれとのことです。ここでは、それでもSQLiteが…という人のため残しておきます。
Roomの関連ページです
Room を使用してローカル データベースにデータを保存する
Room | Android デベロッパー | Android Developers
Room 永続ライブラリ | Android デベロッパー | Android …

~~~

SQLiteのデータは表のような構造で、関係(Relation)と呼ぶ概念でモデル化されています。例えば企業の株価をこのようにデータベース化されているとすると

番号 企業名 株価(USD)
001 Apple 217
002 Google 1105
003 Amazon 1764
004 Microsoft 108

このようなデータベースをSQLiteで作りAndroidで表示させてみましょう。
 

 

SQLiteOpenHelper

 
データベースの作成、データの追加・削除などを管理するためにSQLiteOpenHelperのクラスがあります。これを継承したクラスを作成するところから始めます。
 
例えばSQLiteOpenHelperを継承したTestOpenHelperというクラスを作ります。
 

 
onCreate() でテーブルを作成して、バージョンをあげると onUpgrade() にて新規バージョンのテーブルが作成されバージョンアップします。

 

データベースの作成・削除

 
テーブル作成やアップデートの判別の execSQL() にはSQL文で実行文を文字列で入れて指定します。例えばSQL_CREATE_ENTRIESはこのように記述します。
 

 
これを汎用性と意味がわかるようにしてまとめるとこうなります。(注)文なのでスペースは意味がありますので消さないように
 

 
同様にSQL_DELETE_ENTRIESもこのように書き換えられます。
 

 

データ追加

 
データの書き込みは execSQL() を使うこともできますが、ContentValueを使いマップデータ型のkeyとvalueとして扱うことも可能です。
 

 

データ読み出し

 
読み出しは query() メソッドを使います。実際にここではテーブル名とコラム名の配列を設定するだけの簡単なものとして作りました。
 

 

サンプルコード

 
まとめてみます。EditTextからデータを入力してデータベースを作ってみます。
 
TestOpenHelper.java

 
ActivityからContextをSQLiteOpenHelperを継承したTestOpenHelperに渡し、データベースを作成。読み出しをボタンでデータベースから読出し表示させます。
MainActivity.java

 

レイアウトです。
activity_main.xml

 
リソース
strings.xml

 

データとして企業名と株価をEditTextに入れてデータベースを作っていきます。尚、価格は整数で扱うようにしていますので小数点を使う場合はコードを変更してください
 

 
次は、実際にデータが保存されているのを確認します。
 

SQLiteでデータベースを構築しても、実際どうなっているか確認したい場合があります。 色々な方法がネット上にあるのですが、Android...

 
 
関連ページ:
 
asynctask 00b 100x100 - [Android] データベース SQLite の簡単作成
データを保存するストレージ領域が目的・用途によって区分されてセキュリティー的に厳しくなりました。 対象範囲別外部ストレージ   S...

 
 
References:
Save data using SQLite | Android Developers
SQLite Home Page

誤字脱字、意味不明で分からにゃイ、
などのご意見はこちらから mailフォーム

ブックマークしておくと便利です このエントリーをはてなブックマークに追加

 

アプリ開発が上達するお勧め

アプリ開発を始めたけどわからないところがあり、誰かに聞きたいけど周りにはそんな人はいない…あるいは、会社で働いていて日中そんなに時間をとれないなど、オンラインのプログラミングスクールがいいでしょう。

オンラインスクールは色々ありますが、以下の3つはAndroidが学習できる老舗スクールです。


TECH ACADEMY
Androidアプリコース


こういうものではアプリ作れないと言う意見もありますが、それは結局本人のやる気があるかないかです。やる気があっても独学では突破しにくいところは教えてもらうのが一番早い。


侍エンジニア塾
侍エンジニア塾 無料体験レッスン


とても簡単なことなのに本やネットの画像だけでは分かりにくいことはあります。実際に質問してピンポイントで教えてもらうと、なんだそんなこと、と言うのがけっこうあります。


CodeCamp
~約8,000名の受講生と80社以上の導入実績~
現役エンジニアのオンライン家庭教師CodeCamp




直接(ネットで)誰か分かる人に聞いた方が早く解決して、上達も早いと思います。




シェアする

  • このエントリーをはてなブックマークに追加

フォローする