Android使用Sqlite存儲(chǔ)數(shù)據(jù)用法示例
本文實(shí)例講述了Android使用Sqlite存儲(chǔ)數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
一般在開(kāi)發(fā)程序中,經(jīng)常使用數(shù)據(jù)的存儲(chǔ)功能,如在使用Delphi開(kāi)發(fā)程序時(shí),存儲(chǔ)程序的簡(jiǎn)單設(shè)置的INI文件,在C#開(kāi)發(fā)中有時(shí)也需要存儲(chǔ)簡(jiǎn)單的設(shè)置,個(gè)人一般存儲(chǔ)在XML中,也在INI中存儲(chǔ)過(guò),但是不如XML使用方便,那么這些都是簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)功能,在Android中也支持這樣的文件存儲(chǔ),但是現(xiàn)在這里主要說(shuō)的還是使用SQLite存儲(chǔ)數(shù)據(jù),SQLite是一種跨平臺(tái)的數(shù)據(jù)庫(kù),是單文件式的,如咱們平常見(jiàn)的最多的Access數(shù)據(jù)庫(kù),但是他有比Access更好的平臺(tái)支持,并且支持分頁(yè),現(xiàn)在主要是用于嵌入式的開(kāi)發(fā)。
在開(kāi)發(fā)過(guò)程中其實(shí)可以直接聲明數(shù)據(jù)庫(kù)對(duì)象來(lái)進(jìn)行存儲(chǔ)管理的,代碼如下:
SQLiteDatabase sqlitedb; //數(shù)據(jù)庫(kù)對(duì)象 sqlitedb = this.openOrCreateDatabase(datebaseName, MODE_PRIVATE, null); //執(zhí)行代碼: SqlString = " create table " + tableName + " (_id integer primary key,num integer,data text) "; sqlitedb.execSQL(SqlString);
這種方式需要我們處理的內(nèi)容更多一些,個(gè)人感覺(jué)不是太方便,就像我們開(kāi)發(fā)C#的程序使用SqlHelper一樣,在Android平臺(tái)中也提供了一個(gè)類似的類:
SQLiteOpenHelper 這樣的類
我們可以通過(guò)實(shí)現(xiàn)這個(gè)類來(lái)完成我們的操作,這樣更簡(jiǎn)單和高效:
代碼如下:
import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory; public class DBHelper extends SQLiteOpenHelper { private static final int DB_VERSION = 1; public DBHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); // TODO Auto-generated constructor stub } public DBHelper(Context context, String dBName) { super(context, dBName, null, DB_VERSION); } @Override public void onCreate(SQLiteDatabase db) { // TODO Auto-generated method stub } public void onCreate(SQLiteDatabase db, String createDBSql) { // TODO Auto-generated method stub db.execSQL(createDBSql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub } @Override public void onOpen(SQLiteDatabase db) { // TODO Auto-generated method stub super.onOpen(db); } public void InsertintoDB(SQLiteDatabase db,String sql) { db.execSQL(sql); } public Cursor opendb(SQLiteDatabase db,String sql) { return db.rawQuery(sql, null); } }
在這里只做了一個(gè)簡(jiǎn)單的寫(xiě)作,沒(méi)有寫(xiě)太多方法這個(gè)只是一個(gè)引導(dǎo),可以對(duì)這個(gè)類進(jìn)行擴(kuò)展,這樣使用起來(lái)更方便一些。
下面是一個(gè)簡(jiǎn)單的調(diào)用:
//聲明 SQLiteDatabase db = null; DBHelper dbhelper = null; //實(shí)例化 dbhelper = new DBHelper(this, "DBName"); //方法 void CreateTable() { String sql = "Create Table if not exists " + TABLE_NAME + " ( " + ID + " text not null , " + NAME + " text not null );"; dbhelper.onCreate(db, sql); } void InsertDB(String id, String name) { db = dbhelper.getWritableDatabase(); String sql = "insert into " + TABLE_NAME + " (" + ID + "," + NAME + ") values('" + id + "','" + name + "')"; dbhelper.InsertintoDB(db, sql); } void getDB() { db = dbhelper.getReadableDatabase(); String sql = "select * from " + TABLE_NAME; Cursor cursor = dbhelper.opendb(db, sql); String text = ""; while (cursor.moveToNext()) { for (int i = 0; i < cursor.getColumnCount(); i++) { text += cursor.getString(i); } text += "\n"; } Toast.makeText(this, cursor.getCount() + "\n" + text,Toast.LENGTH_LONG).show(); }
在此只是提供一下簡(jiǎn)單的參考!歡迎批評(píng)指正!
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android操作SQLite數(shù)據(jù)庫(kù)技巧總結(jié)》、《Android數(shù)據(jù)庫(kù)操作技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android編程開(kāi)發(fā)之SD卡操作方法匯總》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android資源操作技巧匯總》、《Android視圖View技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- 詳解Android數(shù)據(jù)存儲(chǔ)—使用SQLite數(shù)據(jù)庫(kù)
- Android SQLite數(shù)據(jù)庫(kù)徹底掌握數(shù)據(jù)存儲(chǔ)
- Android數(shù)據(jù)存儲(chǔ)之SQLite使用
- Android SQLite數(shù)據(jù)庫(kù)增刪改查操作的使用詳解
- Android使用SQLite數(shù)據(jù)庫(kù)的簡(jiǎn)單實(shí)例
- android創(chuàng)建數(shù)據(jù)庫(kù)(SQLite)保存圖片示例
- android開(kāi)發(fā)教程之listview顯示sqlite數(shù)據(jù)
- Android中操作SQLite數(shù)據(jù)庫(kù)快速入門(mén)教程
- Android創(chuàng)建和使用數(shù)據(jù)庫(kù)SQLIte
- Android SQLite數(shù)據(jù)庫(kù)增刪改查操作的案例分析
- Android操作SQLite數(shù)據(jù)庫(kù)(增、刪、改、查、分頁(yè)等)及ListView顯示數(shù)據(jù)的方法詳解
- Android開(kāi)發(fā)之使用SQLite存儲(chǔ)數(shù)據(jù)的方法分析
相關(guān)文章
Android Flutter實(shí)現(xiàn)自定義下拉刷新組件
在Flutter開(kāi)發(fā)中官方提供了多平臺(tái)的下拉刷新組件供開(kāi)發(fā)者使用。本文將改造一下這些組件,實(shí)現(xiàn)自定義的下拉刷新組件,感興趣的可以了解一下2022-08-08Android模擬實(shí)現(xiàn)網(wǎng)易新聞客戶端
這篇文章主要為大家詳細(xì)介紹了Android模擬實(shí)現(xiàn)網(wǎng)易新聞客戶端,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05Android中Xposed框架篇---修改系統(tǒng)位置信息實(shí)現(xiàn)自身隱藏功能實(shí)例
本篇文章介紹了Android中Xposed框架的使用,詳細(xì)的介紹了修改系統(tǒng)位置信息實(shí)現(xiàn)自身隱藏功能實(shí)例,有需要的朋友可以了解一下。2016-11-11Android性能優(yōu)化之JVMTI與內(nèi)存分配
這篇文章主要為大家介紹了Android性能優(yōu)化之JVMTI與內(nèi)存分配,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10一款非常簡(jiǎn)單酷炫的LoadingView動(dòng)畫(huà)效果
這篇文章主要為大家詳細(xì)介紹了一款非常簡(jiǎn)單酷炫的LoadingView動(dòng)畫(huà)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08Android?EventBus粘性事件實(shí)現(xiàn)機(jī)制探究
最近項(xiàng)目做組件化,需要進(jìn)行組件化的通信,有時(shí)候可能會(huì)出現(xiàn)異步的情況,事件接收方還沒(méi)準(zhǔn)備好事件就已經(jīng)發(fā)送過(guò)來(lái)了,這時(shí)候想到了EventBus的粘性事件,這篇文章主要給大家介紹了關(guān)于Android?EventBus粘性事件實(shí)現(xiàn)機(jī)制的相關(guān)資料,需要的朋友可以參考下2022-05-05Android中使用OkHttp包處理HTTP的get和post請(qǐng)求的方法
OkHttp包為安卓開(kāi)發(fā)中的HTTP協(xié)議網(wǎng)絡(luò)編程帶來(lái)了很大的便利,這里我們就來(lái)看一下最基本的、Android中使用OkHttp包處理HTTP的get和post請(qǐng)求的方法:2016-07-07Android開(kāi)發(fā)實(shí)現(xiàn)NFC刷卡讀取的兩種方式
這篇文章主要為大家詳細(xì)介紹了Android開(kāi)發(fā)中實(shí)現(xiàn)NFC刷卡讀取的兩種方式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Android通過(guò)HTTP協(xié)議實(shí)現(xiàn)斷點(diǎn)續(xù)傳下載實(shí)例
本篇文章主要介紹了Android通過(guò)HTTP協(xié)議實(shí)現(xiàn)斷點(diǎn)續(xù)傳下載實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04