上一节学习了使用SQLiteDatabase来操作SQLite数据库的方法,接下来我们开始接触第一个开源库:LitePal。LitePal是一款开源的Android数据库框架,它采用了对象关系映射(ORM)的模式,并将我们平时开发最常用到的一些数据库功能进行了封装,使得不用编写一行SQL语句就可以完成各种建表和增删改查的操作,LitePal的项目主页上也有详细的使用文档,地址是:

https://github.com/LitePalFramework/LitePal

一、配置LitePal

  要在项目中使用开源库,过去是需要下载开源库的Jar包或者源码,然后再集成到我们的项目中,而现在大多数的开源项目都会将版本提交到:jcenter上,我们只需要在:app/build.gradle文件中声明该开源库的引用就可以了。

第一步:编辑:app/build.gradle文件,在dependencies闭包中添加如下内容:前面部分是固定的,最后是版本号,最新的版本号可以在LitePal的项目主页上去查看。

第二步:配置:litepal.xml文件,右击:app/src/main目录 ---> New ---> Directory,创建一个assets目录,然后在assets目录下再新建一个litepal.xml文件,接着编辑litepal.xml文件中的内容:

    <dbname>标签:用于指定数据库名

    <version>标签:用于指定数据库的版本号

    <list>标签:用于指定所有的映射模型

第三步:配置LitePalApplication,修改AndroidManifest.xml中的代码:

  将项目的application配置为:org.litepal.litePalApplication,这样才能让LitePal的所有功能都可以正常工作。(后面我们会对application进行详细的讲解)

二、创建和升级数据库

  前面我们创建数据库是通过自定义一个类继承SQLiteOpenHelper,然后在onCreate()方法中编写建表语句来实现的,而使用LitePal就不用这么麻烦了。我们先将activity_main.xml布局文件(几个按钮)从DatabaseTest项目复制到LitePalTest项目中来。

  LitePal采取的是对象关系映射(ORM)的模式,什么是对象关系映射呢?简单的说,我们使用的编程语言是面向对象语言,而使用的数据库则是关系型数据库,那么将面向对象的语言和面向关系的数据库之间建立的一种映射关系,就是对象关系映射。它赋予我们强大的功能,就是可以用面向对象的思维来操作数据库,而不用再和SQL语句打交道了。使用SQLiteDatabase来创建表时,需要先分析表中应该包括哪些列,然后再编写出一条建表语句,最后在自定义的SQLiteOpenHelper中去执行这条建表语句,但是使用LitePal就不用那么麻烦了:

第一步:定义一个Book类:

第二步:将Book类添加到映射模型列表中,修改:litepal.xml中的代码:

  <mapping>标签:声明我们要配置的映射模型类,注意一定要使用完整的类名,不管有多少模型类需要映射,都使用同样的方式配置在<list>标签中即可

第三步:在MainActivity中任意进行一次数据库的操作,数据库就能自动创建了

第四步:运行程序,点击按钮,查看BookStore数据库和book表是否创建成功

拓展:

  如果我们想要在book表中添加一个press(出版社)列,直接在Book类中再加一个press字段即可;如果我们想要在建一个Category表,就只需要再新建一个Category类,然后将它添加到映射模型列表中就行了。如下所示:

第一步:在Book类中添加press字段:

第二步:新建Category类

第三步:将该表添加到映射模型列表中(注意修改版本号)

第四步:运行程序,查看表列表:

三、LitePal对数据库进行CRUD操作

 3.1、添加数据

  首先回顾一下之前添加数据的方法,需要创建一个ContentValues对象,然后将所有要添加的数据put到这个ContentValues对象中,最后调用SQLiteDatabase的:insert()方法将数据添加到数据库表中。

  而使用LitePal来添加数据,就简单得多了,我们只需要创建出模型类的实例,再通过对应的set方法把数据设置好,最后调用一下:save()方法就可以了。但是这里需要注意的是:刚刚我们使用LitePal进行表管理操作时模型类没有继承其他类,但是进行CRUD操作时就必须要继承LitePalSupport类才行,因为:save()方法就是来只LitePalSupport类

第一步:将Book类继承LitePalSupport类

第二步:在MainActivity中向Book表中添加数据

第三步:运行程序,查看Book表中的数据,我们可以看到数据已经添加成功

3.2、更新数据(book.updateAll()方法)

方式一:

第一步:在MainActivity中对更新按钮进行功能实现。

第二步:运行程序,点击更新按钮,查看Book表中的数据

方式二:

第一步:修改MainActivity中的代码:

第二步:运行程序,点击更新按钮,查看Book表中的数据

总结:

  1、 方式二比方式一更加简洁灵巧

  2、updateAll()方法可以指定一个条件约束,和SQLiteDatabase中的:update()方法的where参数部分有点类似,但是更加简洁,如果不指定条件语句的话,就表示更新所有的数据。

  3、在使用updateAll()方法时,还有一个非常重要的知识点你需要知晓,就是当你想把一个字段的值更新成默认值时,是不可以使用上面的方式来set数据的。我们知道,在Java中的任何一种数据类型的字段都是会有默认值的,int是0,boolean是false,String是null,当我们new出一个Book对象时,其实所有的字段都已经被初始化成默认值了,如果我们想要把数据库表中的page列更新成0,直接调用book.setPage(0)是不可以的,因为即使不调用这行代码,page字段本身也是0,LitePal此时是不会对这个列进更新的,对于所有想要将数据更新成默认值的操作,LitePal统一提供了一个setToDefault()方法,然后传入相应的列名就可以实现了。比如我们将所有书的页数都更新为0,代码如下:

3.3、删除数据(LitePal.deleteAll()方法)

  使用LitePal删除数据的方式主要有两种,第一种比较简单,就是直接调用已存储对象的delete()方法来删除数据。这种方式比较简单,我们就不进行代码演示了,下面看另外一种删除数据的方式:

第一步:在MainActivity中添加删除按钮的点击事件:

第二步:运行程序,点击删除按钮,查看Book表中的数据,我们发现也是为800的“The first Code of Android”这本书已经删除了。

3.4、查询数据(LitePal.findAll()方法)

第一步:给查询按钮添加监听事件,将查询到的数据打印出来

第二步:查看打印结果

拓展:

除了:findAll()方法,LitePal还提供了很多其他非常有用的查询API,如下所示:

我们还可以通过连缀查询来定制更多的查询功能:

对于上面的5个方法,还可以进行任意的连缀组合:

关于LitePal的查询API差不多就介绍到这里,这些API已经足够我们应对绝大多数场景的查询需求了,如果实在有一些特殊需求,上述API满足不了你的时候,LitePal仍然支持使用原生的SQL来进行查询:

Android学习之基础知识九 — 数据存储(持久化技术)之使用LitePal操作数据库的更多相关文章

  1. Android学习之基础知识九 — 数据存储(持久化技术)之SQLite数据库存储

    前面一讲介绍了数据持久化技术的前两种:文件存储.SharedPreferences存储.下面介绍第三种技术:SQLite数据库存储 一.SQLite数据库存储 SQLite数据库是一款轻量级的关系型数 ...

  2. Android学习之基础知识九—数据存储(持久化技术)

    数据持久化是将那些内存中的瞬时数据保存到存储设备,保证即使在手机或电脑关机的情况下,这些数据仍然不会丢失. Android系统中主要提供了3种方式用于简单地实现数据持久化功能:文件存储.SharedP ...

  3. Android学习之基础知识十六 — Android开发高级技巧的掌握

    一.全局获取Context的技巧 前面我们很多地方都使用到了Context,弹出Toast的时候.启动活动的时候.发送广播的时候.操作数据库的时候.使用通知的时候等等.或许目前来说我们并没有为得不到C ...

  4. Android学习之基础知识十三 — 四大组件之服务详解第一讲

    一.服务是什么 服务(Service)是Android中实现程序后台运行的解决方案,它非常适合去执行那些不需要和用户交互而且还要求长期运行的任务.服务的运行不依赖于任何用户界面,即使程序被切换到后台, ...

  5. Android应用开发基础之三:数据存储和界面展现(三)

    生成XML文件备份短信 创建几个虚拟的短信对象,存在list中 备份数据通常都是备份至sd卡 使用StringBuffer拼接字符串 把整个xml文件所有节点append到sb对象里 sb.appen ...

  6. Android学习之基础知识四-Activity活动4讲(Intent传递数据)

    Intent除了可以开启一个活动,还能在启动活动的时候传递数据,此时Intent相当于一个保存数据的库,我们先把数据保存在Intent中,然后再根据各个activity的需要从其中取出数据.  一.使 ...

  7. Android学习之基础知识十五 — 最佳UI体验(Material Design实战)

    一.前言 长久以来,大多数人都认为Android系统的UI并不美观,至少没有iOS系统的美观.以至于很多IT公司在进行应用界面设计的时候,为了保证双平台的统一性,强制要求Android端的界面风格必须 ...

  8. Android学习之基础知识十一 —运用手机多媒体

    一.使用通知(Notification) 通知(Notification)是Android系统中比较有特色的一个功能,当某个应用程序希望向用户发出一些提示信息,而该应用程序又不在前台运行时,就可以借助 ...

  9. Android学习之基础知识十—内容提供器(Content Provider)

    一.跨程序共享数据——内容提供器简介 内容提供器(Content Provider)主要用于在不同的应用程序之间实现数据共享的功能,它提供了一套完整的机制,允许一个程序访问另一个程序中的数据,同时还能 ...

随机推荐

  1. 微信服务号获取openid方法

    public function tetst(){ if(!isset($_GET['code'])){ $APPID = $this->app_id; $ran = rand(1,100); / ...

  2. Python 列表增删改查排序统计

    列表的查 a = ["klvchen", "tom", "jack", "james", "lily" ...

  3. 让js中的函数只有一次有效调用的三种常用方法

    1.通过闭包来实现. <script> window.onload = function () { function once(fn) { var result; return funct ...

  4. sigar获取Windows系统的硬件信息进行JAVA后台系统资源监控

    windows下,将sigar-amd64-winnt.dll复制到jdk的bin目录下或者拷贝到WEB-INF/lib下 linux下,将libsigar-amd64-linux.so拷贝到jdk的 ...

  5. 06:合法 C 标识符

    06:合法 C 标识符 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 . C语言标识符要求: 1. 非保留字: 2. 只包含字母.数字及下划线(“_”). 3. ...

  6. Chrome调试本地文件无法使用window.opener对象进行窗口间值传递

    今天在百度BAE上建了个应用,svn上传后发现页面间互调有些问题,几经查询发现: (1)IE下正常的window.opener.object1.object2页面间对象访问方法在Chrome下不能使用 ...

  7. Jni 线程JNIEnv,JavaVM,JNI_OnLoad(GetEnv返回NULL?FindClass返回NULL?)

    此文章是关于NDK线程的第二篇理论知识笔记.主要有两个点,如下: 1.pthread_create(Too many arguements, expected 1) ?2.线程中如何获取JNIEnv? ...

  8. Chrome Inspect调试stetho出现空白的解决方法

    stetho可以使用chrome调试webview,有网友反映国内不行,亲测了一下是有解决方法的: Chrome://inspect 打开后会发现stetho的页面: 点击inspect,如果没有Fa ...

  9. (后端)shiro:Wildcard string cannot be null or empty. Make sure permission strings are properly formatted.

    访问某页面时,出现了这个异常: java.lang.IllegalArgumentException: Wildcard string cannot be null or empty. Make su ...

  10. sql server全文索引使用中的小坑 (转载)

    一.业务场景 我们在实际生产环境中遇到了这样一种需求,即需要检索一个父子关系的子树数据 估计大家也遇到过类似的场景,最典型的就是省市数据,其中path字段是按层级关系生成的行政区路径: 如果我们已知某 ...