Android開發之Sqliteopenhelper用法執行個體分析_Android

來源:互聯網
上載者:User

本文執行個體講述了Android開發之Sqliteopenhelper用法。分享給大家供大家參考。具體分析如下:

如果在安卓開發中,直接使用Activity中的openOrCreateDatabase(name, mode, factory)會有一系列跟隨的問題。比如說資料庫升級、更新等。

最好是使用其封裝版本:SQLiteOpenHelper

繼承和擴充SQLiteOpenHelper類主要做的工作就是重寫以下兩個 方法。

onCreate(SQLiteDatabase db) : 當資料庫被首次建立時執行該方法,一般將建立表等初始化操作在該方法中執行。

onUpgrade(SQLiteDatabse dv, int oldVersion,int new Version):當開啟資料庫時傳入的版本號碼與當前的版本號碼不同時會調用該方法。

除了上述兩個必須要實現的方法外,還可以選擇性地實現onOpen 方法,該方法會在每次開啟資料庫時被調用。

自己在業務中重寫這些函數,然後通過helper的getWritableDatabase和getReadableDatabase來得到想要操作的資料庫。再進行操作就可以了。

另外,判斷一個表在sqlite中是否存在,可以使用如下方法:

String sql = "SELECT count(*) FROM sqlite_master WHERE type='table' AND name='items'"; Cursor cur = db.rawQuery(sql, null); int count = -1; while (cur.moveToNext()) {   count = cur.getInt(0); } if (count <= 0) {   // 表不存在 } else {}

希望本文所述對大家的Android程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.