標籤:des android style class blog c
本來不太想寫這篇部落格的,但是看到網上的關於android資料庫操作的博文都講得很詳細,對於像我這樣的新手入門瞭解SQLite的基本操作有一定難度,所以我參考了網上的一些部落格文章,並自己親自摸索了一遍,希望寫出這麼一篇博文來記錄SQLite的最基本操作,同時也希望能夠對android的新手們有些協助。
參考部落格:http://www.20864.com/201247/274.html
這裡只是一個示範性的demo,並沒實現什麼具體功能,只實現了對資料庫的增刪查改操作。
以下是實現demo的步驟:
第一步,建立自己的SQL操作類 DBHelper
package com.example.SQLiterTest;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteDatabase.CursorFactory;import android.database.sqlite.SQLiteOpenHelper;import android.util.Log;/** * 可以通過SQLiteOpenHelper的以下兩個方法來或得SQLiteDatabase的對象: * getReadableDatabase() 建立或者開啟一個查詢資料庫 * getWritableDatabase() 建立或者開啟一個可寫資料庫 */public class DBHelper extends SQLiteOpenHelper { /** * 建構函式,必須實現 * @param context 上下文路徑 * @param name 資料庫名稱 * @param factory 可選遊標工廠,通常為NULL * @param version 當前資料庫版本號碼 */ private SQLiteDatabase mDataBase = null; private static final String USER_TABLE = "user"; public DBHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); mDataBase = this.getWritableDatabase(); } //資料庫第一次建立時會調用,一般在其中建立資料庫表 @Override public void onCreate(SQLiteDatabase db) { //使用execSQL()方法執行SQL語句,如果沒有異常,這個方法沒有傳回值 db.execSQL("create table user(id INTEGER PRIMARY KEY AUTOINCREMENT," + "name varchar(20), address TEXT)"); Log.v("mytab","-->onCreate"); } //當資料庫需要修改的時候,Android系統會主動的調用這個方法。 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {} //開啟資料庫時的回呼函數,一般不會用 @Override public void onOpen(SQLiteDatabase db) { super.onOpen(db); Log.v("mytab","-->onOpen"); } @Override public synchronized void close() { super.close(); }}
第二步,在Activity的onCreate函數中實現增刪查改的功能。
package com.example.SQLiterTest;import android.app.Activity;import android.content.ContentValues;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.os.Bundle;import android.util.Log;public class MyActivity extends Activity { /** * Called when the activity is first created. */ private SQLiteDatabase db; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // 擷取處理SQLiteOpenHelper的子類的SQLite的執行個體,如果唯讀,可以採用getReadableDatabase(), // 這個例子我們獎通過SQLiteDatabase執行個體的操作,來進行對資料進行增刪改查詢,採用可寫的方式。 db = new DBHelper(getApplicationContext(),"mydb",null,1).getWritableDatabase(); ContentValues cv = new ContentValues(); cv.put("name", "JackLi"); cv.put("address", "QingYuan"); //插入 db.insert("user",null,cv); Log.v("mytab","-->have insert"); //更新 ContentValues cv2 = new ContentValues(); cv2.put("name","HaiXin"); db.update("user",cv2,"name=?",new String[]{"JackLi"}); Log.v("mytab","-->have updated"); //查詢 String[] columns = {"name", "address"}; Cursor cursor = db.query("user",columns,"name = ?", new String[] {"HaiXin"},null,null,null); while (cursor.moveToNext()) { String myname = cursor.getString(cursor.getColumnIndex("name")); Log.v("mytab","---->"+myname); } //刪除 db.delete("user","name = ?",new String[]{"HaiXin"}); Log.v("mytab","-->have delete"); } @Override protected void onDestroy() { super.onDestroy(); db.close(); }}
總的來說整個過程只有兩步,在第一次運行這個demo時,會建立一個名叫"mydb"的資料庫和一個叫“user”的資料表。
運行程式後,在logcat中會顯示以下一些資訊:
05-19 08:08:30.864 1802-1802/com.example.SQLiterTest V/mytab﹕ -->onOpen05-19 08:08:30.872 1802-1802/com.example.SQLiterTest V/mytab﹕ -->have insert05-19 08:08:30.888 1802-1802/com.example.SQLiterTest V/mytab﹕ -->have updated05-19 08:08:30.888 1802-1802/com.example.SQLiterTest V/mytab﹕ ---->HaiXin05-19 08:08:30.900 1802-1802/com.example.SQLiterTest V/mytab﹕ -->have delete
通過logcat中的資訊可以很清楚的看到程式的執行過程。