Android数据库高手秘籍(九),赶快使用LitePal 2.0版本吧

2024-01-02 07:08

本文主要是介绍Android数据库高手秘籍(九),赶快使用LitePal 2.0版本吧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载请注明出处:https://blog.csdn.net/guolin_blog/article/details/80586028

本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 郭霖 即可关注,每个工作日都有文章更新。

今天很高兴告诉大家一个好消息,LitePal又出新版本了。

算了一下,上个版本1.6.1已经是半年前推出的了,而整个开源项目自2014年推出以来,我已经维护了有四年之久。这四年以来,我不断地完善着LitePal的代码,修复各种大家提出的bug,以及补充各式各样好用的新功能。而今天,时隔半年,LitePal终于迎来了一次大的版本更新,正式发布了2.0.0版本!

从1.6.1直接跨越到2.0.0,说明这次的升级变化还是非常大的。在2.0.0版本当中,我重构了内部大量的代码,使得LitePal整体的架构更加合理和清晰,API接口更加科学,并且重写了数据库的同步处理机制,解决了很多并发操作数据库的问题。最重要的是,LitePal 2.0.0版本现在全面支持Kotlin了!以后不管你是用Java还是Kotlin开发Android程序,都可以100%兼容地使用LitePal,是不是有点小激动呢?那么下面我们就来具体学习一下如何使用新版本的LitePal吧。

升级到2.0.0

升级的方式很简单,如果你使用的是Android Studio,只需要在build.gradle中修改一下配置即可:

dependencies {implementation 'org.litepal.android:core:2.0.0'
}

如果你使用的还是Eclipse,那么可以点击 这里 下载最新版的jar包。

新版本变化

需要大家注意的是,2.0.0版本中几乎所有的API接口全部都变了。但是请不要惊慌,2.0.0版本是完全向下兼容的,也就是说,大家不用担心升级之后会出现大量的错误,之前所有的代码都还是可以正常运行的,只是原来旧的API会被标识为废弃,提醒大家尽快使用新的API而已,如下图所示:

当然,大家也不用一听到所有的API都变了就觉得恐慌,其实一切的变更都是有规律可循的。

那么我们都知道,LitePal本身的用法就非常简单,因此升级新API的过程也同样是非常简单的,下面我们一步步来看。

首先是实体类的继承要进行修改,这是我们过去的写法:

可以看到,现在DataSupport类已经被标为了废弃,虽然暂时还可以正常工作,但是不建议再继续使用了,从LitePal 2.0.0版本开始建议使用LitePalSupport类,我们将代码改成如下所示即可:

将实体类的继承结构更改为LitePalSupport之后,得到的一个隐形好处就是所有的实例CRUD方法都会自动升级到2.0.0版本了,如save()方法,update()方法,delete()方法等等。因此,我们原来存储一条数据该怎么写,现在就还怎么写,比如:

Song song = new Song();
song.setName("hello");
song.setDuration("180");
song.save();

这样就可以存储一条数据到数据库当中了,和之前的写法没有任何变化,但是却使用了LitePal 2.0.0中的最新接口了,因为这个save()方法是来自于LitePalSupport类的。

接下来第二步需要升级的是静态CRUD方法。原来所有的静态CRUD方法都是封装在DataSupport类当中的,比如刚才我们演示过的查询数据库的中数据可以这么写:

而现在,所有的静态CRUD方法都被移动到了LitePal类当中,因此我们只需要将DataSupport修改为LitePal即可,其他的用法都是完全不变的,如下所示:

没错,升级过程就是这么简单。总结一下其实主要就只有两点,如果你是在继承结构中使用了DataSupport,那么就将它改为LitePalSupport,如果你是调用了DataSupport中的静态方法,那么就将它改为LitePal。

不过最后还有一件事需要注意,如果你的项目代码启用了混淆,那么混淆的配置也需要进行相应的修改才行,原来的混淆配置如下所示:

-keep class org.litepal.** {*;
}-keep class * extends org.litepal.crud.DataSupport {*;
}

而由于DataSupport类已经被废弃了,因此这里也需要将混淆文件中的DataSupport改成LitePalSupport才行,如下所示:

-keep class org.litepal.** {*;
}-keep class * extends org.litepal.crud.LitePalSupport{*;
}

将以上的操作都完成之后,那么恭喜你,你的代码已经完全升级到LitePal 2.0.0版本了。


在Kotlin中使用LitePal

Kotlin自去年Google IO大会成为Android一级语言之后,经过了一年多的发展,如今已经正式成为Google心中的亲儿子了。未来使用Kotlin编写Android程序的人会越来越多,因此LitePal也及时跟进,全面支持了Kotlin语言。

下面我来给大家简单演示下如何在Kotlin代码中使用LitePal吧。

首先要定义一个实体类,这里我们就以Book类为例吧。比如Book类中有id、name、page这三个字段,并且继承自LitePalSupport类,如下所示:

class Book(val name: String, val page: Int) : LitePalSupport() {val id: Long = 0
}

可以看到,Kotlin中定义实体类真的是非常简单。需要注意的是,如果你的实体类中需要定义id这个字段,不要把它放到构造函数当中,因为id的值是由LitePal自动赋值的,而不应该由用户来指定。因此这里我们在Book类的内部声明了一个只读类型的id。

然后需要在litepal.xml中声明一下这个实体类,这个属于常规操作了:

<list><mapping class="org.litepal.litepalsample.model.Book" />
</list>

好了!接下来我们就可以进行CRUD操作了,那么由于是首次使用Kotlin来操作LitePal,这里我会将每一个操作都分别演示一下。首先是存储操作,代码如下所示:

val book = Book("第一行代码", 552)
val result = book.save()
Log.d(TAG, "save result is $result , book id is ${book.id}")

可以看到,这里我们先创建了一个Book的实例,并传入书名和页数,然后调用save()方法就可以将这条数据存储到数据库中了。存储结束后这里还用一条打印日志打印出了执行结果,如下所示:

D/MainActivity: save result is true , book id is 1

可以看到,这里显示存储成功,并且book的id值变成了1,说明LitePal在存储成功之后自动给id赋值了。

接下来我们到数据库中具体查看一下吧,如下图所示:

再一次验证存储操作已经成功了。

接下来我们演示一下修改操作,代码如下所示:

val cv = ContentValues()
cv.put("name", "第二行代码")
cv.put("page", 570)
LitePal.update(Book::class.java, cv, 1)

其实基本上Kotlin上的用法大家都会觉得眼熟,因为和Java都是类似的,只是具体语法可能有些不太一样。就比如update()方法接收的第一个参数是个Class对象,在Java中我们会传入Book.class,而在Kotlin中则需要传入Book::class.java。

执行上述代码,然后再到数据库中查看一下,结果如下图所示:

没错,说明我们的修改操作也顺利完成了。

下面看一下删除操作,代码如下所示:

LitePal.delete(Book::class.java, 1)

这里我们指明要删除id为1的这条记录。当然除了按照id删除以外,你还可以按照其他任意条件去删除,比如我们想把页数大于500的书全部都删掉,那么就可以这么写:

LitePal.deleteAll(Book::class.java, "page > ?", "500")

好,现在执行上述任意一行代码,然后到数据库中观察一下,如下图所示:

没有问题,可以看到这里数据库已清空,说明我们的删除操作确实生效了。

最后,再向大家演示一下查询的操作。由于现在数据库中已没有数据可查,那么我们先向库中添加两条数据,然后再执行查询操作,代码如下所示:

Book("第一行代码", 552).save()
Book("第二行代码", 570).save()LitePal.findAll(Book::class.java).forEach {Log.d(TAG, "book name is ${it.name} , book page is ${it.page}")
}

这里调用了findAll()方法,将Book表中的所有数据都查询了出来。查询的结果是一个List集合,因此我们又用了Kotlin中的forEach循环将查询到的每条记录都打印了出来。执行结果如下所示:

D/MainActivity: book name is 第一行代码 , book page is 552
D/MainActivity: book name is 第二行代码 , book page is 570

当然,除了调用findAll()方法之外,我们还可以使用LitePal的连缀查询来对查询条件进行任意地定制:

LitePal.where("name like ?", "第_行代码").order("page desc").limit(5).find(Book::class.java)

这样我们就将在Kotlin中使用LitePal进行CRUD操作全部都演示完了,是不是感觉和Java中一样的简单和方便呢?当然,除了这些新功能之外,我还修复了一些已知的bug,提升了整体框架的稳定性,如果这些正是你所需要的话,那就赶快升级吧。

我没学过LitePal怎么办?

本篇文章是写给已经有LitePal基础的人看的,帮助他们快速地升级到LitePal 2.0。如果你之前并没有学过LitePal,可以参考《第一行代码 第2版》第6章中的内容,里面有非常详尽的LitePal使用讲解。

另外也可以阅读我写的专栏《Android数据库高手秘籍》,同样对LitePal的各种使用方法进行了详细地剖析。


关注我的技术公众号,每天都有优质技术文章推送。关注我的娱乐公众号,工作、学习累了的时候放松一下自己。

微信扫一扫下方二维码即可关注:

        

这篇关于Android数据库高手秘籍(九),赶快使用LitePal 2.0版本吧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/561674

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Mysql数据库聚簇索引与非聚簇索引举例详解

《Mysql数据库聚簇索引与非聚簇索引举例详解》在MySQL中聚簇索引和非聚簇索引是两种常见的索引结构,它们的主要区别在于数据的存储方式和索引的组织方式,:本文主要介绍Mysql数据库聚簇索引与非... 目录前言一、核心概念与本质区别二、聚簇索引(Clustered Index)1. 实现原理(以 Inno

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代