android數(shù)據(jù)存儲-SQLite

簡介

SQLite 是一個軟件庫,實現(xiàn)了自給自足的、無服務(wù)器的恤批、零配置的、事務(wù)性的 SQL 數(shù)據(jù)庫引擎裹赴。SQLite 是在世界上最廣泛部署的 SQL 數(shù)據(jù)庫引擎喜庞。SQLite 源代碼不受版權(quán)限制诀浪。

數(shù)據(jù)類型

SQLite使用動態(tài)類型。內(nèi)容可以存儲為INTEGER延都,REAL雷猪,TEXT,BLOB或NULL晰房。

創(chuàng)建數(shù)據(jù)庫

在實際開發(fā)中求摇,我們需要追尋一下步驟

  1. 確認(rèn)目標(biāo)數(shù)據(jù)庫是否已經(jīng)存在
  2. 如果不存在,首先創(chuàng)建數(shù)據(jù)庫嫉你,然后創(chuàng)建數(shù)據(jù)庫表以及必需的初始化數(shù)據(jù)
  3. 如果存在月帝,打開并確認(rèn)識是否是最新版本
  4. 如果是舊版本,就運行相關(guān)代碼升級到最新版本

Android專門提供了一個SQLiteOpenHelper幫助類幽污,該類有需要實現(xiàn)兩個方法onCreate()onUpgrade(),實現(xiàn)數(shù)據(jù)庫的創(chuàng)建和升級的邏輯

public class MyDatabases extends SQLiteOpenHelper {
    private final String CREATE_TABLE = "create table book( id varchar(20) primary key,name varchar(20),price REAL)";
    public MyDatabases(Context context,String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(CREATE_TABLE);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        
    }
}

增刪改查

SQLiteOpenHelper有兩個非常重要的的實例化方法getWritableDatabase()getReadableDatabase()都返回一個SQLiteDatabase對象用于執(zhí)行不同的數(shù)據(jù)庫邏輯

  • 添加數(shù)據(jù)
    添加數(shù)據(jù)需要使用ContentValues對象對數(shù)據(jù)進行封裝
    MyDatabases myDatabases = new MyDatabases(this,"data.db",null,1);
    SQLiteDatabase sqLiteDatabase = myDatabases.getReadableDatabase();
    ContentValues contentValues = new ContentValues();
    contentValues.put("id","1");
    contentValues.put("name","thinking in java");
    contentValues.put("price","132.11");
    sqLiteDatabase.insert("book",null,contentValues);
    
  • 刪除數(shù)據(jù)
    SQLiteDatabase提供了一個delete()方法:
    int delete(String table, String whereClause, String[] whereArgs){}
    whereClause為約束條件嚷辅,whereArgs為約束條件對應(yīng)的值
    MyDatabases myDatabases = new MyDatabases(this,"data.db",null,1);
    SQLiteDatabase sqLiteDatabase = myDatabases.getReadableDatabase();
    sqLiteDatabase.delete("book","id = ?",new String[]{"1"});
    
  • 修改數(shù)據(jù)
    修改數(shù)據(jù)提供了一個update()方法:
    update(String table, ContentValues values, String whereClause, String[] whereArgs) {}
    values為更新的數(shù)據(jù),whereClause為約束條件距误,whereArgs為約束條件對應(yīng)的值
    ContentValues contentValues = new ContentValues();
    contentValues.put("name","java"); 
    sqLiteDatabase.update("book",contentValues,"id = ?",new String[]{"1"});
    
  • 查詢
    重載了多個query(),最復(fù)雜的如下
    public Cursor query(boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal) {}
參數(shù) 詳解
distinct 設(shè)置為true簸搞,每一行的數(shù)據(jù)必須唯一,否則flase
table 表名
columns 需要查詢的字段准潭,null為全部查詢
selection where約束條件
selectionArgs 為where約束條件提供具體的值
groupBy 指定需要group by的列
having 對group by后的結(jié)果進行約束
orderBy 對查詢結(jié)果進行排序
limit 用于設(shè)置查詢行數(shù)
cancellationSignal 取消操作的信號趁俊,一般用于設(shè)置查詢?nèi)∠麜r的后續(xù)操作
Cursor cursor = sqLiteDatabase.query("book",null,null,null,null,null,null);
List<Book> books = new ArrayList<>();
if(cursor.moveToFirst()){
    Book book;
    do{
        //遍歷Cursor對象,取出數(shù)據(jù)并打印
        book = new Book(cursor.getString(cursor.getColumnIndex("id")), cursor.getString(cursor.getColumnIndex("name")),
cursor.getDouble(cursor.getColumnIndex("price")));
        books.add(book);
    }while(cursor.moveToNext());
}
Log.d("data", books+"s");
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末刑然,一起剝皮案震驚了整個濱河市寺擂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泼掠,老刑警劉巖怔软,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異择镇,居然都是意外死亡挡逼,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門腻豌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來家坎,“玉大人,你說我怎么就攤上這事吝梅∈瑁” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵憔涉,是天一觀的道長订框。 經(jīng)常有香客問我,道長兜叨,這世上最難降的妖魔是什么穿扳? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任衩侥,我火速辦了婚禮,結(jié)果婚禮上矛物,老公的妹妹穿的比我還像新娘茫死。我一直安慰自己,他們只是感情好履羞,可當(dāng)我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布峦萎。 她就那樣靜靜地躺著,像睡著了一般忆首。 火紅的嫁衣襯著肌膚如雪爱榔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天糙及,我揣著相機與錄音详幽,去河邊找鬼。 笑死浸锨,一個胖子當(dāng)著我的面吹牛唇聘,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柱搜,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼迟郎,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了聪蘸?” 一聲冷哼從身側(cè)響起宪肖,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎健爬,沒想到半個月后匈庭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡浑劳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了夭拌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片魔熏。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖鸽扁,靈堂內(nèi)的尸體忽然破棺而出蒜绽,到底是詐尸還是另有隱情,我是刑警寧澤桶现,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布躲雅,位于F島的核電站,受9級特大地震影響骡和,放射性物質(zhì)發(fā)生泄漏相赁。R本人自食惡果不足惜相寇,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望钮科。 院中可真熱鬧唤衫,春花似錦、人聲如沸绵脯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛆挫。三九已至赃承,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間悴侵,已是汗流浹背瞧剖。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留畜挨,地道東北人筒繁。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像巴元,于是被迫代替她去往敵國和親毡咏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容