android SQLiteOpenHelper使用示例

咱們你們都知道Android平臺提供給咱們一個數據庫輔助類來建立或打開數據庫,這個輔助類繼承自SQLiteOpenHelper類,在該類的 構造器中,調用Context中的方法建立並打開一個指定名稱的數據庫對象。繼承和擴展SQLiteOpenHelper類主要作的工做就是重寫如下兩個 方法。android

onCreate(SQLiteDatabase db) : 當數據庫被首次建立時執行該方法,通常將建立表等初始化操做在該方法中執行。sql

onUpgrade(SQLiteDatabse dv, int oldVersion,int new Version):當打開數據庫時傳入的版本號與當前的版本號不一樣時會調用該方法。數據庫

除了上述兩個必需要實現的方法外,還能夠選擇性地實現onOpen 方法,該方法會在每次打開數據庫時被調用。app

SQLiteOpenHelper 類的基本用法是:當須要建立或打開一個數據庫並得到數據庫對象時,首先根據指定的文件名建立一個輔助對象,而後調用該對象的getWritableDatabase 或 getReadableDatabase方法 得到SQLiteDatabase 對象。ide

調用getReadableDatabase 方法返回的並不老是隻讀數據庫對象,通常來講該方法和getWriteableDatabase 方法的返回狀況相同,只有在數據庫僅開放只讀權限或磁盤已滿時纔會返回一個只讀的數據庫對象。this

下面經過一個簡單的小例子說明SQLiteOpenDatabase的用法,其中包括建立數據庫、插入數據、更新 、查詢等等,咱們將查詢後獲取到的數據顯示到TextView上,看一下運行後的效果。sqlite

android SQLiteOpenHelper使用示例 - 戰狼 - 戰狼對象

MySQLiteHelper Java代碼 package xiaohang.zhimeng;繼承

import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory;索引

public class MySQLiteHelper extends SQLiteOpenHelper{ //調用父類構造器 public MySQLiteHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); }

/**

  • 當數據庫首次建立時執行該方法,通常將建立表等初始化操做放在該方法中執行.
  • 重寫onCreate方法,調用execSQL方法建立表
  • */ @Override public void onCreate(SQLiteDatabase db) { db.execSQL("create table if not exists hero_info("
  • "id integer primary key,"
  • "name varchar,"
  • "level integer)");

}

//當打開數據庫時傳入的版本號與當前的版本號不一樣時會調用該方法 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { }

}

package xiaohang.zhimeng;

import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory;

public class MySQLiteHelper extends SQLiteOpenHelper{ //調用父類構造器 public MySQLiteHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); }

/**

  • 當數據庫首次建立時執行該方法,通常將建立表等初始化操做放在該方法中執行.
  • 重寫onCreate方法,調用execSQL方法建立表
  • */ @Override public void onCreate(SQLiteDatabase db) { db.execSQL("create table if not exists hero_info("
  • "id integer primary key,"
  • "name varchar,"
  • "level integer)");

}

//當打開數據庫時傳入的版本號與當前的版本號不一樣時會調用該方法 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { }

}

Activity01 Java代碼 package xiaohang.zhimeng;

import android.app.Activity; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.graphics.Color; import android.os.Bundle; import android.widget.TextView;

public class Activity01 extends Activity { MySQLiteHelper myHelper; TextView tv;

@Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); tv = (TextView)findViewById(R.id.tv); //建立MySQLiteOpenHelper輔助類對象 myHelper = new MySQLiteHelper(this, "my.db", null, 1); //向數據庫中插入和更新數據 insertAndUpdateData(myHelper); //查詢數據 String result = queryData(myHelper); tv.setTextColor(Color.RED); tv.setTextSize(20.0f); tv.setText("名字\t等級\n"+result);

}

//向數據庫中插入和更新數據 public void insertAndUpdateData(MySQLiteHelper myHelper){ //獲取數據庫對象 SQLiteDatabase db = myHelper.getWritableDatabase(); //使用execSQL方法向表中插入數據 db.execSQL("insert into hero_info(name,level) values('bb',0)"); //使用insert方法向表中插入數據 ContentValues values = new ContentValues(); values.put("name", "xh"); values.put("level", 5); //調用方法插入數據 db.insert("hero_info", "id", values); //使用update方法更新表中的數據 //清空ContentValues對象 values.clear(); values.put("name", "xh"); values.put("level", 10); //更新xh的level 爲10 db.update("hero_info", values, "level = 5", null); //關閉SQLiteDatabase對象 db.close(); }

//從數據庫中查詢數據 public String queryData(MySQLiteHelper myHelper){ String result = ""; //得到數據庫對象 SQLiteDatabase db = myHelper.getReadableDatabase(); //查詢表中的數據 Cursor cursor = db.query("hero_info", null, null, null, null, null, "id asc"); //獲取name列的索引 int nameIndex = cursor.getColumnIndex("name"); //獲取level列的索引 int levelIndex = cursor.getColumnIndex("level"); for (cursor.moveToFirst();!(cursor.isAfterLast());cursor.moveToNext()) { result = result + cursor.getString(nameIndex)+ "\t\t"; result = result + cursor.getInt(levelIndex)+"\n"; } cursor.close();//關閉結果集 db.close();//關閉數據庫對象 return result; }

@Override protected void onDestroy() { SQLiteDatabase db = myHelper.getWritableDatabase();//獲取數據庫對象 //刪除hero_info表中全部的數據 傳入1 表示刪除全部行------>點擊back按鈕 db.delete("hero_info", "1", null); super.onDestroy(); } }

相關文章
相關標籤/搜索