LitePal用法与实践

LitePal是一个开放源码的Android库,非常容易地使用SQLite数据库。无需编写SQL语句的情况下,可以完成大多数数据库操作,包括创建或升级表、CRUD操作、聚合函数等。

  • 项目是郭霖(第一行代码作者)团队开源维护,有非常完善的中文文档
  • 持续更新中,针对kotlin语法进行过优化,使用起来非常丝滑
  • 几乎为零配置(只有一个配置文件,几乎没有属性)
  • 自动维护所有表(例如创建、更改或删除表)
  • 简易完善而流畅的API

准备

导入

    implementation 'org.litepal.android:kotlin:3.0.0'

配置

唯一的配置文件,在assets下新建一个litepal.xml然后按一下规则配置

<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <!--
        定义应用程序的数据库名称。
        默认情况下,每个数据库名都应该以.db结尾。
        如果你没有用。db来命名你的数据库,LitePal会自动为你加上后缀。
        For example:
        下面写法会生成BookStore.db
        -->
    <dbname value="BookStore" />
    <!--
        定义数据库的版本。
        每次你想要升级数据库,修改映射标记中定义的版本值+ 1,数据库升级将会被自动处理。
        详情见后文的升级.
        -->
    <version value="1" />
    <!--
        用映射标签指定的modle在表中定义数据模型.
        LitePal会在模型中定义的字段将映射到对应表的列中。
        For example:
        下面Song 属于package com.routon.litepal.litepaltest.dbmodel
        -->
    <list>
        <mapping class="com.routon.litepal.litepaltest.dbmodel.Album" />
        <mapping class="com.routon.litepal.litepaltest.dbmodel.Song" />
        <mapping class="com.routon.litepal.litepaltest.dbmodel.Book" />
    </list>
    <!--
        定义.db文件的位置。
        "internal"表示.db文件将存储在内部存储的数据库文件夹中,没有人可以访问,默认设置。。
        "external"表示.db文件将存储在主外部存储设备上的目录路径中,应用程序可以在该路径中放置它所拥有的每个人都可以访问的持久文件。
        也可以自定义:
        For example:
        下面路径即为 /storage/emulated/0/routon/litePal/db/BookStore.db
        -->
    <storage value="routon/litePal/db" />
</litepal>

配置完成

配置LitePalApplication

在我们的Application中

    override fun onCreate() {
        ...
        LitePal.initialize(this)
        ...
    }

即可
LitePal.initialize(this)此方法需要尽早调用,且使用application context作为参数

开始使用

1.定义model

java:

public class Song extends LitePalSupport {
    @Column(nullable = false)
    private String name;
    private int duration;
    @Column(defaultValue="无用")
    private String uselessField;
    // generated getters and setters.
    ...
}

kotlin:

class Book(
    @Column(unique = true, defaultValue = "unknown")
    val name: String,
    val page: Int) : LitePalSupport() {
    val id: Long = 0
}

需要注意的是,如果你的实体类中需要定义id这个字段,不要把它放到构造函数当中,因为id的值是由LitePal自动赋值的,而不应该由用户来指定。因此这里我们在Book类的内部声明了一个只读类型的id。
然后将这些模型添加到litepal.xml

    <list>
        <mapping class="com.routon.litepal.litepaltest.dbmodel.Song" />
        <mapping class="com.routon.litepal.litepaltest.dbmodel.Book" />
    </list>

下一次操作数据库时将生成这些表。例如,获取SQLiteDatabase有以下代码:

  LitePal.getDatabase()

在实践中发现,LitePal需要文件读取权限,也就是说,这一步操作需要放到获取权限之后

2.升级表

只要修改想改模型就行了
然后在配置文件litepal.xml中把<version value="x" />改为<version value="x+1" />就可以了

注意

有些升级条件LitePal无法处理,升级表中的所有数据都将被清除:

  • 添加一个注释为unique = true.
  • 将字段的注释更改为unique = true.
  • 将字段的注释更改为nullable = false.

注意以上情况,这样会导致数据丢失。

3.增删改查

继承自LitePalSupport的每个模型都有save()方法。
直接调用即可

val song = Song()
song.name = "first song"
song.duration = 180
song.save()

如此简单

val songs = LitePal
    .where("name like ?", "first%").limit(1)
    .find<Song>()

songs[0].name="second song"
songs[0].save()

songs[0].name="second song"
songs[0].delete()

其他的例子

实在是语义性太强了,不需要注释,自行阅读吧

val albumToUpdate = LitePal.find<Album>(1)
albumToUpdate.price = 20.99f // raise the price
albumToUpdate.save()

val albumToUpdate = Album()
albumToUpdate.price = 20.99f // raise the price
albumToUpdate.update(id)

val albumToUpdate = Album()
albumToUpdate.price = 20.99f // raise the price
albumToUpdate.updateAll("name = ?", "album")

LitePal.delete<Song>(id)

LitePal.deleteAll<Song>("duration > ?" , "350")

val song = LitePal.find<Song>(id)

val allSongs = LitePal.findAll<Song>()

val songs = LitePal.where("name like ? and duration < ?", "song%", "200").order("duration").find<Song>()

4.异步操作

默认情况下,每个数据库操作都位于主线程上。如果操作可能花费很长时间,例如保存或查询大量记录。就可能需要使用异步操作。
LitePal支持对所有CRUD方法的异步操作。
例如:要在后台线程上查找song表中的所有记录,请使用如下代码。

LitePal.findAsync<Song>().listen { allSongs ->

}

5.其他

可以支持多数据库,也有升级监听.暂时不需要,可以自行了解

结语

相关demo git库
https://git.dev.tencent.com/zhoulei26/android-scarlet.git

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,916评论 2 89
  • 学车小记 我从4月份报名到现在,终于把科三准备并考完了。感悟还有的,科目一是4.25考,科目二是6.22,科三是8...
    铉铉小星星阅读 219评论 0 0
  • 冬天是什么呢? 就是我裹着厚睡衣准备去厨房做饭 沾点凉水吹点凉风立马就缩回了我温暖的小窝 拿起手机,点起了外卖。 ...
    廿小阙阅读 101评论 0 0