Android数据库框架-Archiver(LiteOrm)的使用

2023-10-24 01:58

本文主要是介绍Android数据库框架-Archiver(LiteOrm)的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自:Android数据库框架-Archiver(LiteOrm)的使用



 在Android开发中,大家开发不同项目,不同的项目就不有不同需求。但是不管是什么项目都会涉及到数据存储。比如SharePreferences,SQLite,File等方式。但是我最近开发的项目是一个有IM的项目。所以需要用到SQLite,原因是这其中的数据并不是所有数据都是在后台拉取的。也有需要自己去创建表,和填充数据的功能。下面具体讲讲我在项目中使用的数据库和所遇到的数据库问题。

      LiteOrm: LiteOrm是一个速度快、小巧却强大的android ORM框架类库,LiteOrm让你一行代码实现数据库的增删改查操作,以及实体关系的持久化和自动映射。

  • 轻量,专注,性能优先,线程无关,专注数据及其关系(关系是重点)存储和读取。 
  • 不需要工具辅助,实体不需要无参构造,不需要繁多注解,约定大约配置,一切多余的,都不需要。
  • 使用极致简约:db.save(u); db.delete(u); db.deleteAll(U.class);

    开源项目地址:https://github.com/litesuits/android-lite-orm
    作者个人主页:http://litesuits.com/

    我为什么选择用LiteOrm的原因:

  •       因为我开发的项目是一个IM的项目,当然要允许账号切换当账号切换之后上一个用户对应的数据和下一个用户对应的数据怎么区分?这是一个细节上的问题。所以我采用的QQ的做法,一个用户对应一个数据库。有些库写的也不错,可是考虑的不周全,一个用户对应一个数据库是最好的,但是有些库没有考虑进去,但是LiteOrm可以自定义数据库名字已经目录。
  •      在当我使用其他的库的时候,报错了,尼玛我研究看瞎都没有看出到底是什么错,没有一个准确的提示告诉我到底是什么地方错误。比如我其中有一个字段是from,这个是数据库关键字,总是创建不成功,但是那个库又报一些看不懂错,根本没有说倒是是哪错了。但是在我使用LiteOrm的时候哪里错了会明确的告诉你。
  •      因为LiteOrm体积小,专一,一个库只做一件事,是什么库就做什么事情,有些库什么功能都有,又是HTTP请求,又是下载图片,但是我只需要用到其中一个模块而已。


    1、创建数据库:


?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/**
      * 创建数据库细节 :
      * 细节一:每次启动都会调用这个方法,是否会重复创建,或者说怎么判断这个数据库已经存在。
      * 回答:尽在第一次创建,开发这不用关心存在否。
      *
      * 细节二:如果指定目录创建在SD卡上,卸载APP之后,重新安装,以前的创建的数据库还存在
      * 回答:如果不想这样,就不要指定创建在SD卡上面,默认创建就在APP里。卸载后数据库就不存在了
      *
      * 细节三:创建数据库有两种模式,第一种是单一操作没有级联关系的,第二种是级联操作。
      * 创建单一操作模式:LiteOrm.newSingleInstance(_activity, DB_NAME);
      * 创建级联操作模式:LiteOrm.newCascadeInstance(_activity, DB_NAME);
      */
     public static void createDb(Context _activity,Object userId){
          //DB_NAME = Environment.getExternalStorageDirectory().getAbsolutePath()+"/pinme.db";
         DB_NAME = "pinme_" + userId.toString() + ".db" ;
             liteOrm = LiteOrm.newCascadeInstance(_activity, DB_NAME);
             liteOrm.setDebugged( true );
     }


  解释一下创建数据库Cascade 和 Single 两种模式的的区别:

    LiteOrm是基类,是基础。有两个孩子实现:Cascade 和 Single。

    如果使用Single,效率最高,只保存当前Model,简单的首选。

    如果使用Cascade实例,将会无限级联操作(不会死循环),将所有与这个Model相关的实体、关系都保存下来。 重点介绍下Cascade,举个例子,一个学校有10个学院(一对多),一个学院10个专业,一个专业10个班级,一个班级10个老师,一个老师10个学生(多对多关系)。只要调用cascade.save( school ); 那么这个学校,以及10 0000个学生 ,和他们的关系,都保存下来了。 删除也一样,都删了

 2、如何创建表:都说了ORM嘛,所以不需要像android原生的代码那样去写SQL语句去创建。只需要如下创建实体类


?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class BaseModel implements Serializable {
     // 设置为主键,自增
     @PrimaryKey (AssignType.AUTO_INCREMENT)
     public int id;
     public int getId() {
         return id;
     }
     public void setId( int id) {
         this .id = id;
     }
}

  

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@Table ( "Conversation" ) //指定表名,可任意写
public class Conversation extends BaseModel {
     
     public static final String MESSAGEID = "messageId" ;
     public static final String ISVISIBILITY = "isVisibility" ;
         //这里又是一个实体类的LIST,可以理解为另外一张表。这么写,就代表 Conversation表和User表是 一对多关系
          <span></span> private List<User> user;
     private String nickName;
     private String headImgUrl;
     private String content;
     private String sendDate;
     private int msgType;
     private int subType;
     private int messageId; // 用于话题聊天的id,和私聊的 Userid
     private int senderUserId;
     private Boolean isVisibility = true ;
     private int messageType;
     private int messageNum;
     
     //  以下省略一堆 get和set方法
}


 问题来了:现在实体类创建了,那什么时候创建表,如何创建表,在哪里写创建表的代码 ?

   其实不需要去刻意的去写创建表的代码,当我们把 Conversation 对象填充数据后 使用 liteOrm.save(Conversation );即可,会自动创建Conversation 


  下面是我自己根据我自己的需求封装的一个帮助类

  

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
public class LiteOrmDBUtil {
     
     public static String DB_NAME;
     public static LiteOrm liteOrm;
     
     public static void createDb(Context _activity,Object userId){
         DB_NAME = "pinme_" + userId.toString() + ".db" ;
         liteOrm = LiteOrm.newCascadeInstance(_activity, DB_NAME);
         liteOrm.setDebugged( true );
     }
     
     
     public static LiteOrm getLiteOrm(){
         return liteOrm;
     }
     
     /**
      * 插入一条记录
      * @param t
      */
     public static <T> void insert(T t){
         liteOrm.save(t);
     }
     
     /**
      * 插入所有记录
      * @param list
      */
     public static <T> void insertAll(List<T> list){
         liteOrm.save(list);
     }
     
     /**
      * 查询所有
      * @param cla
      * @return
      */
     public static <T> List<T> getQueryAll(Class<T> cla){
         return liteOrm.query(cla);
     }
     
     /**
      * 查询  某字段 等于 Value的值
      * @param cla
      * @param field
      * @param value
      * @return
      */
     public static <T> List<T> getQueryByWhere(Class<T> cla,String field,String [] value){
         return liteOrm.<T>query( new QueryBuilder(cla).where(field + "=?" , value));
     }
     
     /**
      * 查询  某字段 等于 Value的值  可以指定从1-20,就是分页
      * @param cla
      * @param field
      * @param value
      * @param start
      * @param length
      * @return
      */
     public static <T> List<T> getQueryByWhereLength(Class<T> cla,String field,String [] value, int start, int length){
         return liteOrm.<T>query( new QueryBuilder(cla).where(field + "=?" , value).limit(start, length));
     }
     /**
      * 删除所有 某字段等于 Vlaue的值
      * @param cla
      * @param field
      * @param value
      */
     public static <T> void deleteWhere(Class<T> cla,String field,String [] value){
         liteOrm.delete(cla, WhereBuilder.create().where(field + "=?" , value));
     }
     
     /**
      * 删除所有
      * @param cla
      */
     public static <T> void deleteAll(Class<T> cla){
         liteOrm.deleteAll(cla);
     }
     
     /**
      * 仅在以存在时更新
      * @param t
      */
     public static <T> void update(T t){
         liteOrm.update(t,ConflictAlgorithm.Replace);
     }
     
     
     public static <T> void updateALL(List<T> list){
         liteOrm.update(list);
     }
     
     
     public static void Text(){
         
         //我们把这个对象当做以填充数据的后的对象
         Conversation mConversation = new Conversation();
         
         List<Conversation> list = new ArrayList<Conversation>();
         for ( int i = 0 ; i < 10 ; i++) {
             list.add(mConversation);
         }
         
         
         //1、插入单条数据
         LiteOrmDBUtil.insert(mConversation);
         
         //2、插入多条数据
         LiteOrmDBUtil.insertAll(list);
         
         //3、查询Conversation表中所有记录
         List<Conversation> list = LiteOrmDBUtil.getQueryAll(Conversation. class );
         
         //4、查询Conversation表中 isVisibility 字段 等于 true 的记录
         List<Conversation> list =  LiteOrmDBUtil.getQueryByWhere(Conversation. class , Conversation.ISVISIBILITY, new String[]{ "true" });
         
         //5、查询Conversation表中 isVisibility 字段 等于 true 的记录,并且只取20条 
         List<Conversation> list =  LiteOrmDBUtil.getQueryByWhereLength(Conversation. class , Conversation.ISVISIBILITY, new String[]{ "true" }, 0 , 20 );
         
         //6、删除Conversation表中 isVisibility 字段 等于 true 的记录
         LiteOrmDBUtil.deleteWhere(Conversation. class ,Conversation.ISVISIBILITY , new String[]{ "true" });
         
         //7、删除所有
         LiteOrmDBUtil.deleteAll(Conversation. class );
         
         
     }
}

这篇关于Android数据库框架-Archiver(LiteOrm)的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen