Android资源收录Android杂识Android 开发知识总结

LitePal 的基本用法

2017-04-29  本文已影响372人  SkyRiN

快速配置

dependencies {
    compile 'org.litepal.android:core:1.4.1'
}
<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <dbname value="BookStore" ></dbname>

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

    <list>
    </list>
</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;
    }
}

创建和升级数据库

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;
    }
    ...
}
<?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>
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {  
    @Override                                                              
    public void onClick(View v) {                                          
        Connector.getDatabase();                                           
    }                                                                      
});                                                                        
<?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>

添加数据

public class Book extends DataSupport{
    private int id;
    private int pages;
    ...
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();                                                   
        }                                                                  
    }                                                                      
});                                                                        

更新数据

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实例,然后调用对应方法来设置需要更新的数据,最后调用updateAll()来更新表,这里updateAll()我们传入了一个类似于 sqlite 中 where 语句的条件约束来指明我们要更新的是哪条数据,如果这里不增加约束的话,整张表的数据都将被更新。上面的示例表示我要更新 name 字段为 《湖畔》price 字段为 99.6 这条数据的 authorKeigoname《白夜行》

Book book = new Book();
book.setToDefault("pages");

book.updateAll();

上面代码的意思就是,将所有书的页数都更新为 0 ,因为updateAll()方法中没有条件约束,操作对所有数据都生效了。

删除数据

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()来删除数据,第一个参数为指定表,第二个参数为约束条件,不指定约束则删除所有数据,同updateAll()原理相似。

查询数据

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());      
        }                                                               
    }                                                                   
});                                                                     
Book firstBook = DataSupport.findFirst(Book.class);
Book lastBook = DataSupport.findLast(Book.class);
List<Book> Books = DataSupport.select("name","author").find(Book.class);
List<Book> Books = DataSupport.where("author=?","skyrin").find(Book.class);
List<Book> Books = DataSupport.order("price ASC").find(Book.class);
List<Book> Books = DataSupport.limit(3).find(Book.class);
List<Book> Books = DataSupport.limit(3).offset(1).find(Book.class);
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 的数据,结果按 pages 降序排列

Cursor c = DataSupport.findBySQL("select * from Book where author=? and pages>?","skyrin","300");
上一篇 下一篇

猜你喜欢

热点阅读