Android系統集成了一個輕量級的資料庫:SQLite,所以Android對資料庫的支持很好,每個應用都可以方便的使用它。SQLite作為一個嵌入式的資料庫引擎,專門適用於資源有限的設備上適量數據存取,現在的主流移動設備像Android、iPhone等都使用SQLite作為複雜數據的存儲引擎,.....
Android系統集成了一個輕量級的資料庫:SQLite,所以Android對資料庫的支持很好,每個應用都可以方便的使用它。SQLite作為一個嵌入式的資料庫引擎,專門適用於資源有限的設備上適量數據存取,現在的主流移動設備像Android、iPhone等都使用SQLite作為複雜數據的存儲引擎,並且它是以手機記憶體為儲存的。
那麼,實際開發項目中有大量數據需要讀寫,並且需要面臨大量用戶的併發儲存的情況呢。就不應該把數據存放在手機等移動設備的SQLite資料庫里,移動設備的儲存能力和計算能力都不足以讓它充當伺服器的角色。雖然SQLite支持大部分SQL-92語法,也可以使用SQL語句,和其他的主要 SQL 資料庫沒什麼區別。但SQLite並不像Oracle、MySQL資料庫那樣需要安裝、啟動伺服器進程,SQLite資料庫只是一個文件。
綜上所述,我們可以總結出SQLite資料庫的特點:
面向資源有限的設備;
沒有伺服器進程;
所有數據存放在同一文件中,可自由複製;
跨平臺;
操作方便,使用標準的CRUDE語句,ContentResolver.query(), update(), delete() insert()。
還有其他的特點:效率出眾,這是無可否認的; 十分適合存儲結構化數據 ;方便在不同的Activity,甚至不同的應用之間傳遞數據。
在我們為移動設備開發應用程式時,也許就要使用到SQLite來存儲我們大量的數據,所以我們就需要掌握移動設備上的SQLite開發技巧
可以充當伺服器
且只利用很少的記憶體就有很好的性能
1.3 例子
4. SQLite資料庫:
3.1 案例:創建SQLite資料庫
-
創建資料庫需要使用的api:SQLiteOpenHelper
-
必須定義一個構造方法:
//arg2:資料庫文件的名字 //arg3:游標工廠 //arg4:資料庫版本 public MyOpenHelper(Context context, String name, CursorFactory factory, int version){}
- 資料庫被創建時會調用:onCreate方法
- 資料庫升級時會調用:onUpgrade方法
-
- 創建資料庫步驟:
//創建OpenHelper對象
MyOpenHelper oh = new MyOpenHelper(getContext(), "person.db", null, 1);
//獲得資料庫對象,如果資料庫不存在,先創建資料庫,後獲得,如果存在,則直接獲得
SQLiteDatabase db = oh.getWritableDatabase();
- getWritableDatabase():打開可讀寫的資料庫
- getReadableDatabase():在磁碟空間不足時打開只讀資料庫,否則打開可讀寫資料庫
-
在創建資料庫時創建表
public void onCreate(SQLiteDatabase db) { // TODO Auto-generated method stub db.execSQL("create table person (_id integer primary key autoincrement, name char(10), phone char(20), money integer(20))"); }
- 代碼:
- 創建MyOpenHelper類繼承 SQLiteOpenHelper
package com.bokeyuan.createsqlite; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; public class MyOpenHelper extends SQLiteOpenHelper { public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { //name:資料庫文件的名字 //factory:游標工廠 //version:資料庫的版本號 super(context, name, factory, version); // TODO Auto-generated constructor stub } //資料庫創建時,此方法調用 @Override public void onCreate(SQLiteDatabase db) { // TODO Auto-generated method stub System.out.println("資料庫被創建了");
//創建表
db.execSQL("create table person(_id integer primary key autoincrement, name char(10), phone char(20), money integer(10))"); } //資料庫升級時,此方法調用 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub System.out.println("資料庫升級了"); } }
-
- 這裡不再用前臺視圖佈局,直接用單元測試框架。
在com.bokeyuan.createsqlite.domian包中創建Test.java 並繼承 AndroidTestCase類。
package com.bokeyuan.createsqlite.domian; import com.bokeyuan.createsqlite.MyOpenHelper; import android.database.sqlite.SQLiteDatabase; import android.test.AndroidTestCase; public class Test extends AndroidTestCase { public void Test() { // 創建資料庫 //1.創建OpenHelper對象 //獲取一個虛擬上下文 MyOpenHelper oh = new MyOpenHelper(getContext(), "people.db", null, 2); //2.創建資料庫 //如果資料庫不存在,那麼先創建,再打開,如果資料庫已經存在,側直接打開 SQLiteDatabase db = oh.getWritableDatabase(); //如果磁碟不足,資料庫只讀 // SQLiteDatabase db = oh.getReadableDatabase(); } }
-
- 在清單文件AndroidManifest.xml設置指令集和庫:
<instrumentation
android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.bokeyuan.createsqlite"></instrumentation>
<uses-library android:name="android.test.runner"/>
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.bokeyuan.createsqlite" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="19" android:targetSdkVersion="19" /> <instrumentation android:name="android.test.InstrumentationTestRunner" android:targetPackage="com.bokeyuan.createsqlite"></instrumentation> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <uses-library android:name="android.test.runner" /> <activity android:name=".MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>View Code
資料庫存儲在 data/< 項目文件夾 >/databases/ 下。我們可以用SQLite Professional打開。
資料庫創建時,此方法調用 說明onCreate()方法被調用了,資料庫被創建了
把version改成2,Run As →Android JUint Test後, 調用onUpgrade()方法,資料庫升級了
//1.創建OpenHelper對象
//獲取一個虛擬上下文
MyOpenHelper oh = new MyOpenHelper(getContext(), "people.db", null, 2);
參考資料