文档章节

android快速开发框架afinal(数据库篇)

方毅超
 方毅超
发布于 2014/04/28 11:31
字数 1609
阅读 136
收藏 2

今天给大家介绍下#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

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

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("afinal@tsz.net");
        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自动给我们创建了数据库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配置一下:

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又自动给我们创建了表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://my.oschina.net/yangfuhai/blog/87459

 

 

 

 

本文转载自:http://my.oschina.net/yangfuhai/blog/87459

共有 人打赏支持
方毅超
粉丝 0
博文 11
码字总数 0
作品 0
揭阳
程序员
私信 提问
Afinal 0.2 发布 Android的快速开发框架(ORM,IOC)

Afinal是一个开源的android的orm和ioc应用开发框架,其特点是小巧灵活,代码入侵量少。 在android应用开发中,通过afinal的ioc框架,诸如ui绑定,事件绑定,通过注解可以自动绑定。通过afina...

理工男海哥
2012/10/29
7K
12
使用android快速开发框架afinal的FinalDb操作android数据库

今天给大家介绍下#afinal#来操作android的数据库sqlite。 #afinal#是一个android的orm、ioc快速开发框架,里面包含了四大功能:空间的id绑定和事件绑定功能;网络图片的显示功能(里面包含了...

理工男海哥
2012/11/06
0
49
Android的快速开发框架,Afinal 0.2.1 发布

Afinal 是一个android的 orm 和 ioc 框架。而且封装了android中的httpClient,使其更加简单易用。使用finalBitmap,无需考虑bitmap在android中加载的时候oom的问题和快速滑动的时候图片加载位...

xiahuawuyu
2012/11/08
0
0
Android--快速开发框架 afinal

版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/chaoyu168/article/details/51014398 Afinal简介 Afinal 是一个android的sqlite orm 和 ioc 框架。同时封装了andro...

sealin
2016/03/30
0
0
移动开发者必须知道的Android框架推荐

一些总结出来的Android快速开发框架,全部都是开源框架,附带项目地址,是开发学习的绝佳资料。 thinkAndroid项目 github地址:https://github.com/white-cat/ThinkAndroid 功 能:ThinkAndr...

程序袁_绪龙
2014/09/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Cookie 显示用户上次访问的时间

import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServlet;import javax.serv......

gwl_
今天
1
0
网络编程

第14天 网络编程 今日内容介绍  网络通信协议  UDP通信  TCP通信 今日学习目标  能够辨别UDP和TCP协议特点  能够说出UDP协议下两个常用类名称  能够说出TCP协议下两个常用类名称...

stars永恒
今天
1
0
二进制相关

二进制 众所周知计算机使用的是二进制,数字的二进制是如何表示的呢? 实际就是逢二进一。比如 2 用二进制就是 10。那么根据此可以推算出 5的二进制等于 10*10+1 即为 101。 在计算机中,负数以...

NotFound403
昨天
3
0
day22:

1、写一个getinterface.sh 脚本可以接受选项[i,I],完成下面任务: 1)使用格式:getinterface.sh [-i interface | -I ip] 2)当用户使用-i选项时,显示指定网卡的IP地址;当用户使用-I选项...

芬野de博客
昨天
2
0
Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现

自Spring Cloud Alibaba发布第一个Release以来,就备受国内开发者的高度关注。虽然Spring Cloud Alibaba还没能纳入Spring Cloud的主版本管理中,但是凭借阿里中间件团队的背景,还是得到不少...

程序猿DD
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部