Android SQLite最簡單demo實現(增刪查改)

來源:互聯網
上載者:User

標籤: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中的資訊可以很清楚的看到程式的執行過程。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.