使用android快速开发框架afinal的FinalDb操作android数据库

原文地址:http://my.oschina.net/yangfuhai/blog/87459

今天给大家介绍下#afinal#来操作android的数据库sqlite。

#afinal#是一个android的orm、ioc快速开发框架,里面包含了四大功能:空间的id绑定和事件绑定功能;网络图片的显示功能(里面包含了强大的缓存框架);数据库sqlite的操作功能;http数据的读取功能(支持ajax方式读取);

#afinal#开源网址:https://github.com/yangfuhai/afinal

这篇文章主要是介绍afinal的功能之一FinalDb组件,其他组件请关注我的博客吧,以后将会一一介绍:

# afinal#的FinalDb组件是android的一个轻量级的orm框架,使用简单,一行代码就可以完成数据库的各种操作功能。

首先我们来创建一个测试实体类 User.java

?


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

package com.devchina.ormdemo;

import java.util.Date;

public class User {

    

    private int id;

    private String name;

    private String email;

    private Date registerDate;

    private Double money;

    

    /////////////getter and setter 不能省略哦///////////////

    public int getId() {

        return id;

    }

    public void setId(int id) {

        this.id = id;

    }

    public String getName() {

        return name;

    }

    public void setName(String name) {

        this.name = name;

    }

    public String getEmail() {

        return email;

    }

    public void setEmail(String email) {

        this.email = email;

    }

    public Date getRegisterDate() {

        return registerDate;

    }

    public void setRegisterDate(Date registerDate) {

        this.registerDate = registerDate;

    }

    public Double getMoney() {

        return money;

    }

    public void setMoney(Double money) {

        this.money = money;

    }

    

    

    

}

这个实体类要注意一点就是getter和setter是不能省略的哦,,,,因为afinal的finalDb最终会调用setter去给实体类的属性赋值。

现在实体类创建完毕了,我们来写我们的第一个demo:

AfinalOrmDemoActivity.java

?


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

package com.devchina.ormdemo;

import java.util.Date;

import java.util.List;

import net.tsz.afinal.FinalActivity;

import net.tsz.afinal.FinalDb;

import net.tsz.afinal.annotation.view.ViewInject;

import android.os.Bundle;

import android.util.Log;

import android.widget.TextView;

public class AfinalOrmDemoActivity extends FinalActivity {

    

    

    @ViewInject(id=R.id.textView) TextView textView; //这里使用了afinal的ioc功能,以后将会讲到

    

    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        

        FinalDb db = FinalDb.create(this);

        

        User user = new User();

        user.setEmail("[email protected]");

        user.setName("探索者");

        user.setRegisterDate(new Date());

        

        db.save(user);

        

        List<User> userList = db.findAll(User.class);//查询所有的用户

        

        Log.e("AfinalOrmDemoActivity", "用户数量:"+ (userList!=null?userList.size():0));

        

        textView.setText(userList.get(0).getName()+":"+user.getRegisterDate());

    }

}

很简单吧,就一个FinalDb db = FinalDb.create(this),然后db.save(user);就可以把我们定义的实体类保存到数据库去啦。我们来看输出日志:

什么?就这样就保存到sqlite数据库里面去了?可是我们还没有创建数据库,也没有创建表呀?怎么可能?

这里,我要跟大家说的是afinal自己去创建啦,简单吧。

我们来看下adt的File Exploer 查看database目录,下面确实有一个afinal.db文件,如下图:

 我们把afinal.db导出来后,通过sqlite数据库打开afinal.db,如下图:

同时afinal自动给我们创建来表:com_devchina_ormdemo_User,由此看出afinal会以类名为表名自动创建表:我们再过来看下表的数据:

到这里,相信大家能明白了,原理afinal自动给我们创建了数据库afinal.db同时给我们创建了表com_devchina_ormdemo_User,保存的时候,afinal自动把数据保存到sqlite表里面去了。

这时候,估计大家的疑问又起来了

afinal自动创建了数据库afinal.db,同时自动创建了表com_devchina_ormdemo_User。可是,我们不想创建数据库afinal.db,也不想让我们的表示com_devchina_ormdemo_User,那我们应该怎么办呢?

这一些呀,afinal都已经想好了。

接下来,我们来介绍下afinal的orm注解功能。

第一个,配置数据库中的表名  net.tsz.afinal.annotation.sqlite.Table,我们来给user,java配置一下:

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

package com.devchina.ormdemo;

import java.util.Date;

import net.tsz.afinal.annotation.sqlite.Table;

@Table(name="user_test")

public class User {

    

    private int id;

    private String name;

    private String email;

    private Date registerDate;

    private Double money;

    

    /////////////getter and setter///////////////

    //代码太长,略getter setter,开发中不能省略

}

这里和上边唯一不同的是 多了一个注解 @Table(name="user_test"),只要我们配置了这个以后,我们再来看下afinal创建的数据库和表:

由此,我们可以看出来,afinal又自动给我们创建了表user_test,但是要注意的是com_devchina_ormdemo_User这个表afinal并没有去删除,所以这里也要提醒下大家,我们在重新设计了类的结构或者属性的时候,先手动删除掉直接的数据,否则就会有垃圾数据保存在数据库里面,当然,不删除也可以,不会有任何的影响。

在上面的讲述中,细心的朋友可能会注意到了一个问题,afinal自动把user的id的这个属性当做了主键。而且自动增长。

可是,可是在我们的开发过程中,我们的user可能没有id这个属性啊,可能是userId,或者又可能是其他我们喜欢的属性,那怎么办呢?

没有关系:afinal有给我们准备了另一个注解:net.tsz.afinal.annotation.sqlite.Id,通过这个,我们就可以给我们的实体类定义主键啦

afinal的主键机制是:

当给某个属性添加注解@id的时候,该属性就是主键(一个类中只有一个主键),保存在数据库中的列名为属性的名称,@Id(column="userId")给属性添加注解的时候,保存在数据库的列名是userId,当这个属性没有的时候,afinal自动回去该类查找_id属性,_id属性也没有的时候,afinal就会自动去查找id属性。如果连id属性也没有,那么afinal就报错啦,afinal的orm规则中,表示必须有主键的,而且只能有一个(目前暂时不支持复合主键)。

回到刚才的问题,afinal给我们自动创建数据库afinal.db,可是,我们不想创建让数据库名是afinal.db,那怎么办呢?

afinal的创建时候有多个方法的重载。

在create的方法中,

isDebug表示是否是debug模式,debug模式中,使用afinal操作数据库的时候就会答应SQL语句的log,

dbName就是数据库的名称啦。

所以这里,我们传入我们自己想要的数据库名称就行了。

其实afinal的FinalDb模块中,还有很多其他的功能,比如一对多,多对一的配置和注解等等。等待大家挖掘了。

afinal的orm注解中有:

Id------->注解注解

Property------>属性注解

Table------->数据表注解

ManyToOne-------->多对一注解

OneToMany--------->一对多注解

Transient------->忽略属性注解(如果该属性添加这个注解,afinal的orm功能将忽略该属性)

源代下载地址:

http://pan.baidu.com/s/1i3vWSkP

里面没有jar包,自己去afinal的广发网站下载最新jar包

时间: 2024-10-14 19:01:41

使用android快速开发框架afinal的FinalDb操作android数据库的相关文章

Android 快速开发框架Afinal

本文转载自:http://www.oschina.net/p/afinal/ Afinal简介 Afinal 是一个android的sqlite orm 和 ioc 框架.同时封装了android中的http框架,使其更加简单易用: 使用finalBitmap,无需考虑bitmap在android中加载的时候oom的问题和快速滑动的时候图片加载位置错位等问题. Afinal的宗旨是简洁,快速.约定大于配置的方式.尽量一行代码完成所有事情. 目前Afinal主要有四大模块: FinalDB模块:a

Android的快速开发框架afinal

afinal 是一个android的 orm 和 ioc 框架.而且封装了android中的httpClient,使其更加简单易用. afinal是android应用开发的终极框架. FinalDB使用方法: FinalDb db = FinalDb.create(this);                         User user = new User(); user.setEmail("[email protected]"); user.setId(1); user.s

看大师讲解Android快速开发框架EasyAndroid

前几天做了小应用,感觉小有成就,名字叫"长见识了",是一款趣味答题类的游戏,题目各种火爆各种经典,下载地址,看似一个简单的答题小游戏却是五脏俱全,从开发流程上都进行了严格的规范,大家有空可以下载玩玩~ 在这个应用中,用到了我以前集成的一个快速开发框架-EasyAndroid,这个框架我以前在做项目的时候总结,整理出来的,对于快速开发Android应用非常实用. 其实,Android应用的开发并不难,我们拿到一款Android应用后,百分之九十以上无外乎有这么几个功能: 1,IOC Mo

android快速开发框架

一.依赖注入DI通过依赖注入减少View.服务.资源简化初始化,事件绑定等重复繁琐工作1. AndroidAnnotations(Code Diet) android快速开发框架项目地址:https://github.com/excilys/androidannotations文档介绍:https://github.com/excilys/androidannotations/wiki官方网站:http://androidannotations.org/特点:(1)依赖注入:包括view,ext

Android 快速开发框架CommonLibsForAndroid(有Demo)

这个项目所包含的功能,全部是从实际项目中提取,开发这个类库的初衷也只是为了方便自己开发Android项目.由于时间所限,目前大量的内容还没整理到这个开源项目中,doc和demo也有所欠缺,我将尽快完善.而其中大量不合理的内容,也将逐步改进. 欢迎大家提各种意见,当然更欢迎fork和pull request. https://github.com/cymcsg/CommonLibsForAndroid CommonLibsForAndroid Using CommonLibs is a fast

Android快速开发框架ZBLibrary源码分享

坐标标准库ZBLibrary,是一个MVP架构的Android快速开发框架,提供一套开发标准(UI,Data,Listener)以及模板和工具类并规范代码. 封装层级少,简单高效兼容性好.Android Studio.Eclipse多平台支持. OKHttp.图片加载.自动缓存以及各种Base.Demo.UI.Util直接用.一句话就能实现全局滑动返回. BaseHttpListActivity,几行代码搞定http请求列表 加载和缓存: BaseView,自定义View竟然如此简单: 万能的E

【源码分享下载】每日更新之Android快速开发框架LoonAndroid

Android快速开发框架LoonAndroid 服务分类: 其他 使用服务: 其他 功能分类: 其他 支持平台: Android 运行环境: Android 开发语言: Java 开发工具: Eclipse 源码大小: 14.65MB 源码下载地址:http://www.devstore.cn/code/info/74.html 源码简介 主要有以下模块: (1) 自动注入框架(只需要继承框架内的application既可) (2) 图片加载框架(多重缓存,自动回收,最大限度保证内存的安全性)

Android快速开发框架-ZBLibrary 源码分享

坐标标准库ZBLibrary,是一个MVP架构的Android快速开发框架,提供一套开发标准(UI,Data,Listener)以及模板和工具类并规范代码.封装层级少,简单高效兼容性好.一句代码就可实现全局滑动返回(可重写):集成方便快捷的照片选择器.日期选择器.地址选择器.时间刷新器等. 丰富的功能 简单的实现 详细的注释 规范的风格 下载地址 ?https://github.com/TommyLemon/Android-ZBLibrary 下载试用 ZBLibraryDemoApp.apk

afinal logoAndroid的快速开发框架 afinal

Afinal简介 Afinal 是一个android的sqlite orm 和 ioc 框架.同时封装了android中的http框架,使其更加简单易用: 使用finalBitmap,无需考虑bitmap在android中加载的时候oom的问题和快速滑动的时候图片加载位置错位等问题. Afinal的宗旨是简洁,快速.约定大于配置的方式.尽量一行代码完成所有事情. 目前Afinal主要有四大模块: FinalDB模块:android中的orm框架,一行代码就可以进行增删改查.支持一对多,多对一等查