Android开发之——数据库框架之LitePal

简述

LitePal是郭神(郭霖)在2014年的杰作,Github地址:LitePal。LitePal是一款开源的Android数据库框架,它采用了对象关系映射(ORM)的模式,并将我们平时开发时最常用到的一些数据库功能进行了封装,使得不用编写一行SQL语句就可以完成各种建表、増删改查的操作。并且LitePal很"轻",jar包只有100k不到,而且近乎零配置,这一点和hibernate这类的框架有很大区别。

LitePal的基本配置

引入Jar包或依赖

dependencies 
{
    compile 'org.litepal.android:core:1.6.1'
}

配置litepal.xml

在main/assets目录下创建一个litepal.xml文件,复制以下代码进去

<?xml version="1.0" encoding="utf-8"?>  
<litepal>  
    <dbname value="数据库名" ></dbname>  
    <version value="数据库版本号,用于更新数据库" ></version>  
<list>
    <!--这里是类映射-->  
</list>  
</litepal>

配置LitePalApplication

这里有两种方式:

  • 指定application name为LitePalApplicatio
  • 自定义Application,并添加application name

LitePal的用法

创建实体类

每个实体类对应一张数据表,这里创建两个实体类Song和Album

public class Song extends DataSupport 
{
    @Column(nullable = false)
    private String name;
    private int duration;
    // generated getters and setters.
}

public class Album extends DataSupport 
{

    @Column(unique = true, defaultValue = "unknown")
    private String name;
    private float price;
    private int number;
    //generated getters and setters.
}

创建的数据表分别为:

加入新表对就实体类的引用

增删改查

增加数据(保存数据)

    Album album = new Album();
    album.setName("album");
    album.setPrice(10.99f);
    album.setNumber(100);
    album.save();

    Song song1 = new Song();
    song1.setName("song1");
    song1.setDuration(150);
    song1.save();

修改数据(更新数据)

这里有提供两种操作:

  • 第一种:

      Song songToUpdate = DataSupport.find(Song.class, 1);
      songToUpdate.setDuration(300);
      songToUpdate.save();
      Toast.makeText(this, "数据已更新" , Toast.LENGTH_SHORT).show();
    
  • 第二种:

      Song songToUpdate = new Song();
      songToUpdate.setDuration(300); // raise the price
      songToUpdate.update(1);
    

删除数据

这里也有两种操作:

  • 删除某一条件
    DataSupport.delete(Song.class, 1);
  • 删除满足条件所有
    DataSupport.deleteAll(Song.class, "duration > ?", "100");

查找数据

List<Song> allSongs = DataSupport.findAll(Song.class);      

参考:
LitePalSample