前言:之前使用Android内置的数据库,感觉一大堆SQL语句,一不小心就错了,很难受,学习了这个LItePal的开源数据库框架,瞬间觉得Android内置的数据库简直是垃圾般的存在

LitePal GitHub首页:https://github.com/LitePalFramework/LitePal

配置步骤

1.添加依赖

切换project模式,展开APP的文件夹,找到build.gradle文件,去里面添加依赖,这里我用的是最新版本,可以在LitePal的Github官网上找到最新的版本

2.配置LitePal.xml文件及相关设置

在main文件夹中新建一个asstes文件夹,之后,创建LitePal.xml,复制LitePal上的GItHub给出的代码,这里我就直接写了,其中,dbname代表数据库的名称,version代表版本号,list标签之下有表(专业术语为映射模型类),这里之后会提及

此外,我们还需要在AndroidMainfest文件中添加一行代码android:name="org.litepal.LitePalApplication"

3.创建一个Java Bean类

这里创建了一个书的bean类,有着三个成员变量,之后,使用alt+insert,选择getter and setter,添加get与set方法

4.在LItePal.xml文件中list标签下配置表(映射模型类)

记得包名要写完整

使用步骤:

1.创建和升级数据库

在相关activity的java文件直接使用LitePal的getDatabase方法创建数据库,即是添加下面的代码即可,写在onClick事件中即可,这里就不放截图

  LitePal.getDatabase();

升级数据库,直接在Bean的java文件中添加新的成员变量及其的get与set方法即可,升级数据库的代码还是使用上面的那一行代码

举个例子,例如上述,我们想要添加一个出版社的列,我们只需要在Book里面创建一个成员变量,及get与set方法,之后,去LitePal.xml文件中,将version的版本加1,也就是改为2即可,其他的都不需要更改

例如,我们想要再加一张表,也是类似的操作,创建一个Bean类,之后,在LitePal.xml文件中使用mapping标签,同时,将版本号加一,也就是改为2即可,其他的也是不需要改变

2.添加数据

修改模型类(也就是Book),使其继承DataSupport

之后,我们只需要新建一个对象,调用其set方法,为其里面的成员变量赋值,之后,调用save方法,就是成功地往数据库中添加了数据

3.修改(更新)数据

更新的操作其实很简单,使用udateAll方法即可,例如,我们要将上面书名为The Last的作者改为John,价格改成16

updateAll里面写了约束条件,也就是书名为The Last的那一条数据,修改,如果updateAll里面无参数,就是将表里面的数据的作者与价格更改为John和16

4.删除数据

调用DataSupport的deleteAll方法,与上面的updateAll类似,参数里填约束条件,如果不写,就是删除整张表

     DataSupport.deleteAll(Book.class,"name is ?","The Last");//删除名字为The Last的数据
     DataSupport.deleteAll(Book.class,"name is ? and price is ?","The Last","15");//删除名字为The Last,价格为15的的数据
 DataSupport.deleteAll(Book.class,"price < ?","16");//删除价格低于16的数据

5.查找数据

查找方法调用的DataSupport的findAll方法即可,下面给出示例代码

  select指定查询列,where查找出符合约束条件的数据,order将查询结果排序,limit限制查询数据数目


     List<Book> books = DataSupport.findAll(Book.class);//查找Book这张表的全部数据,返回的是一个List
List<Book> books1 = DataSupport.select("name","price").find(Book.class);//指定查询Book这张表中的name与price两列的数据,返回的也是一个List
List<Book> books2 = DataSupport.where("price > ?","16").find(Book.class);//指定在Book这张表查找符合价格大于16(约束条件)的数据,返回的是一个List
List<Book> books4 = DataSupport.order("price desc").find(Book.class);//将查询结果按照价格从高到低排序(desc 降序),不写或者asc则是升序
List<Book> books5 = DataSupport.limit(3).find(Book.class);//查询Book表中的前三条数据

 值得一提的是,可以使用findBySQL方法进行原生的查询,也就是之前使用内置数据库的方法,返回的是一个Cursor对象,这里我就不使用了

Android开发——使用LitePal开源数据库框架的更多相关文章

  1. Android开发——使用LitePal开源数据库

    前言:之前使用Android内置的数据库,感觉一大堆SQL语句,一不小心就错了,很难受,学习了这个LItePal的开源数据库,瞬间觉得Android内置的数据库简直是垃圾般的存在 LitePal Gi ...

  2. android开发之使用SQLite数据库存储

    http://blog.csdn.net/jason0539/article/details/16360835 SQLite 介绍 SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且 ...

  3. 在Android 开发中使用 SQLite 数据库笔记

    SQLite 介绍   SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能.此外它还是开源的,任何人都可以使用它.许多开源项目((Mozilla, PH ...

  4. Android开发中用到的第三方框架汇总

    最近上网搜索了一些框架资料,整理了以下常用框架,希望在项目中有所帮助. 1.网络请求框架 android-async-http 该网络框架的介绍文章地址:http://www.cnblogs.com/ ...

  5. Android开发使用的常见第三方框架汇总

    本文转载:http://blog.csdn.net/liuhaomatou/article/details/44857005 1.volley 项目地址 https://github.com/sman ...

  6. Android开发使用的常见第三方框架

    1.SlidingMenu 官网:https://github.com/jfeinstein10/SlidingMenu 网友使用:http://blog.csdn.net/yangyu2012122 ...

  7. Android开发笔记:打包数据库

    对于数据比较多的控制一般会加入SQLite数据库进行数据存储,在打包时这些数据库是不自动打包到apk中的,如何创建数据库呢 方法1:将创建数据库的sql语句在SQLiteHelper继承类中实现,在第 ...

  8. Android开发--数据存储之数据库操作

    简介: SQLite 的介绍: SQLite数据库属于文本型的数据库,它是以文本的形式来保存的.Android提供了对 SQLite 数据库的完全支持,应用程序中的任何类都可以通过名称来访问任何的数据 ...

  9. android项目中使用开源数据库litepal

    下载地址 https://github.com/LitePalFramework/LitePal 参考文档 http://blog.csdn.net/guolin_blog/article/detai ...

随机推荐

  1. Tensorboard可视化(关于TensorFlow不同版本引起的错误)

    # -*- coding: utf-8 -*-"""Created on Sun Nov 5 15:28:50 2017 @author: Administrator&q ...

  2. C语言面试题分类->指针

    有关指针的经典面试题 C语言为何如此长寿并实用?C++为什么有那么多精彩?指针可以说是C/C++中的灵魂所在,虽然早期中pascal也有指针,但是和C/C++比起来不是一个级别的.今天为大家深入浅出的 ...

  3. CountDownLatch使用场景

    正如每个Java文档所描述的那样,CountDownLatch是一个同步工具类,它允许一个或多个线程一直等待,直到其他线程的操作执行完后再执行.在Java并发中,countdownlatch的概念是一 ...

  4. C++ Opencv remap()重映射函数详解及使用示例

    一.重映射及remap()函数介绍 重映射,就是把一幅图像中某位置的像素放置到另一图像指定位置的过程.即: 在重映射过程中,图像的大小也可以同时发生改变.此时像素与像素之间的关系就不是一一对应关系,因 ...

  5. [Swift]LeetCode47. 全排列 II | Permutations II

    Given a collection of numbers that might contain duplicates, return all possible unique permutations ...

  6. [Swift]LeetCode287. 寻找重复数 | Find the Duplicate Number

    Given an array nums containing n + 1 integers where each integer is between 1 and n (inclusive), pro ...

  7. php 168任意代码执行漏洞之php的Complex (curly) syntax

    今天了解了php 168的任意代码执行漏洞,Poc: http://192.168.6.128/pentest/cms/php168/member/post.php?only=1&showHt ...

  8. HBase之CF持久化系列(续2)

    正如上篇博文所说,在本节我将为大家带来StoreFlusher.finalizeWriter..如果大家没有看过我的上篇博文<HBase之CF持久化系列(续1)>,那我希望大家还是回去看一 ...

  9. Thrift 代码分析

    Thrift的基本结束 Thrift是一个跨语言的服务部署框架,最初由Facebook于2007年开发,2008年进入Apache开源项目.Thrift通过IDL(Interface Definiti ...

  10. SpringBoot Mybatis EnumTypeHandler自定义统一处理器

    需求 mybatis目前已经内嵌入了springboot中了,这说明其目前在数据访问层的绝对优势.而我们在开发的过程中,往往会在程序中使用枚举(enum) 来表示一些状态或选项,而在数据库中使用数字来 ...