LitePal 的基本用法


快速配置

  • AS添加依賴如下
dependencies {
    compile 'org.litepal.android:core:1.4.1'
}
  • 接著在項目的assets目錄下面新建一個litepal.xml文件,并將以下代碼拷貝進去:
<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <dbname value="BookStore" ></dbname>

    <version value="1" ></version>

    <list>
    </list>
</litepal>
  • 在Application中初始化LitePal
public class MyApplication extends Application {
    private static Context context;
    @Override
    public void onCreate() {
        super.onCreate();
        context = getApplicationContext();
        LitePal.initialize(context);
    }

    public static Context getContext(){
        return context;
    }
}

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

  • 先創(chuàng)建一個tableBean
public class Book {
    private int id;
    private int pages;
    private String author;
    private String name;
    private double price;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public int getPages() {
        return pages;
    }
    ...
}
  • 將Book類添加到模型映射表中
<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <dbname value="BookStore" ></dbname>

    <version value="1" ></version>

    <list>
        <mapping class="com.example.admin.turingts.Book"></mapping>
    </list>
</litepal>
  • 然后在進行任意一次數(shù)據(jù)庫操作則數(shù)據(jù)庫會被創(chuàng)建出來
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {  
    @Override                                                              
    public void onClick(View v) {                                          
        Connector.getDatabase();                                           
    }                                                                      
});                                                                        
  • 如果要升級數(shù)據(jù)庫也無需做備份相關(guān)的復(fù)雜邏輯,例如增加新表后要升級數(shù)據(jù)庫,如下修改即可
<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <dbname value="BookStore" ></dbname>

    <version value="2" ></version>

    <list>
        <mapping class="com.example.admin.turingts.Book"></mapping>
        <mapping class="com.example.admin.turingts.Category"></mapping>
    </list>
</litepal>

添加數(shù)據(jù)

  • LitePal要求進行CRUD的模型表必須繼承自DataSupport類,所以將Book類進行如下修改
public class Book extends DataSupport{
    private int id;
    private int pages;
    ...
  • 接著我們向Book表中插入數(shù)據(jù),如下
findViewById(R.id.btn_add).setOnClickListener(new View.OnClickListener() { 
    @Override                                                              
    public void onClick(View v) {                                          
                                                                           
        for (int i = 0; i < 10; i++) {                                     
            Book book = new Book();                                        
            book.setAuthor("Keigo");                                    
            book.setName("《湖畔》");                                        
            book.setPages(10 * i);                                         
            book.setPrice(99.6);                                           
            book.setPress("E.T.O");                                        
            book.save();                                                   
        }                                                                  
    }                                                                      
});                                                                        

更新數(shù)據(jù)

  • LitePal提供了updateAll()方法來更新表,操作如下
findViewById(R.id.update).setOnClickListener(new View.OnClickListener() { 
    @Override                                                             
    public void onClick(View v) {                                         
        Book book = new Book();                                           
        book.setAuthor("Keigo");                                         
        book.setName("《白夜行》");                                           
        book.updateAll("name=? and price=?", "《湖畔》", "99.6");           
    }                                                                     
});                                                                       

可以看到我們先new出了一個Book實例,然后調(diào)用對應(yīng)方法來設(shè)置需要更新的數(shù)據(jù),最后調(diào)用updateAll()來更新表,這里updateAll()我們傳入了一個類似于 sqlite 中 where 語句的條件約束來指明我們要更新的是哪條數(shù)據(jù),如果這里不增加約束的話,整張表的數(shù)據(jù)都將被更新。上面的示例表示我要更新 name 字段為 《湖畔》price 字段為 99.6 這條數(shù)據(jù)的 authorKeigoname《白夜行》

  • 使用updateAll()還有一點需要注意,就是當(dāng)你想要更新某個字段的值為默認(rèn)值時,不能再使用set()。比如更新 pages 為 0,直接調(diào)用book.setPages(0)是無效的,因為在 java 中 int 的默認(rèn)值就是 0 ,所以此時LitePal將不會對此更新,對于要更新的數(shù)據(jù),LitePal為我們提供了一個setToDefault()方法,我們傳入相應(yīng)字段名就可以了,如下寫法
Book book = new Book();
book.setToDefault("pages");

book.updateAll();

上面代碼的意思就是,將所有書的頁數(shù)都更新為 0 ,因為updateAll()方法中沒有條件約束,操作對所有數(shù)據(jù)都生效了。

刪除數(shù)據(jù)

  • LitePal刪除數(shù)據(jù)的方式有兩種,一種直接通過已存儲對象的delete()方法刪除,另一種方式如下
findViewById(R.id.delete).setOnClickListener(new View.OnClickListener() {
    @Override                                                            
    public void onClick(View v) {                                        
        //通過delete()刪除                                                   
        Book book = new Book();                                          
        if (book.isSaved()){                                             
            book.delete();                                               
        }                                                                
        //通過DataSupport.deleteAll()刪除                                    
        DataSupport.deleteAll(Book.class, "pages>?", "80");              
    }                                                                    
});                                                                                             

這里使用了DataSupport.deleteAll()來刪除數(shù)據(jù),第一個參數(shù)為指定表,第二個參數(shù)為約束條件,不指定約束則刪除所有數(shù)據(jù),同updateAll()原理相似。

查詢數(shù)據(jù)

  • LitePal查詢數(shù)據(jù)的方式相當(dāng)人性化,例如查詢一張表中的數(shù)據(jù),它會自動為我們賦值
findViewById(R.id.query).setOnClickListener(new View.OnClickListener() {
    @Override                                                           
    public void onClick(View v) {                                       
        List<Book> Books = DataSupport.findAll(Book.class);             
        for (Book book : Books) {                                       
            Log.d(MainActivity.this.TAG,"name:"+book.getName());        
            Log.d(MainActivity.this.TAG,"pages:"+book.getPages());      
            Log.d(MainActivity.this.TAG,"author:"+book.getAuthor());    
            Log.d(MainActivity.this.TAG,"price:"+book.getPrice());      
        }                                                               
    }                                                                   
});                                                                     
  • 除了findAll()之外 LitePal 還提供了其它便捷的 API,例如查詢Book表中第一條數(shù)據(jù)
Book firstBook = DataSupport.findFirst(Book.class);
  • 查詢Book表中最后一條數(shù)據(jù)
Book lastBook = DataSupport.findLast(Book.class);
  • select()方法用于指定查詢哪幾列數(shù)據(jù),例如只獲取 name and author 兩列數(shù)據(jù)
List<Book> Books = DataSupport.select("name","author").find(Book.class);
  • where()方法用于指定查詢的約束條件,比如查詢 author 是 skyrin 的數(shù)據(jù)
List<Book> Books = DataSupport.where("author=?","skyrin").find(Book.class);
  • order()方法用于對指定結(jié)果排序,例如按照 price 升序排列 Book 中的數(shù)據(jù)
List<Book> Books = DataSupport.order("price ASC").find(Book.class);
  • limit()方法用于指定查詢結(jié)果的數(shù)量,比如只查詢表中前3條數(shù)據(jù)
List<Book> Books = DataSupport.limit(3).find(Book.class);
  • offset()用于指定查詢結(jié)果的偏移量,比如從第二條開始往后獲取3條數(shù)據(jù)
List<Book> Books = DataSupport.limit(3).offset(1).find(Book.class);
  • 最后你可以使用以上5條規(guī)則進行組合,來完成一項復(fù)雜查詢
List<Book> Books = DataSupport.select("name", "pages")
                        .where("pages>?", "300")
                        .order("pages desc")
                        .limit(10)
                        .offset(5)
                        .find(Book.class);

以上代碼表示查詢 Book 表中 從 6 ~ 15 條字段為 name 和 pages 且 pages 大于 300 的數(shù)據(jù),結(jié)果按 pages 降序排列

  • 最后的最后當(dāng)以上所有方式都無法滿足你變態(tài)的查詢需求時,LitePal 還支持了原生 SQL 語法查詢
Cursor c = DataSupport.findBySQL("select * from Book where author=? and pages>?","skyrin","300");
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,238評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,430評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,134評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,893評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,653評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,136評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,212評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,372評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,888評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,738評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,939評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,482評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,179評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,588評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,829評論 1 283
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,610評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,916評論 2 372

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