当前位置:操作系统 > 安卓/Android >>

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

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

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

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

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


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

01
package com.devchina.ormdemo;
02
 
03
import java.util.Date;
04
 
05
public class User {
06
    
07
    private int id;
08
    private String name;
09
    private String email;
10
    private Date registerDate;
11
    private Double money;
12
    
13
    /////////////getter and setter 不能省略哦///////////////
14
    public int getId() {
15
        return id;
16
    }
17
    public void setId(int id) {
18
        this.id = id;
19
    }
20
    public String getName() {
21
        return name;
22
    }
23
    public void setName(String name) {
24
        this.name = name;
25
    }
26
    public String getEmail() {
27
        return email;
28
    }
29
    public void setEmail(String email) {
30
        this.email = email;
31
    }
32
    public Date getRegisterDate() {
33
        return registerDate;
34
    }
35
    public void setRegisterDate(Date registerDate) {
36
        this.registerDate = registerDate;
37
    }
38
    public Double getMoney() {
39
        return money;
40
    }
41
    public void setMoney(Double money) {
42
        this.money = money;
43
    }
44
    
45
    
46
    
47
}
这个实体类要注意一点就是getter和setter是不能省略的哦,,,,因为afinal的finalDb最终会调用setter去给实体类的属性赋值。


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

AfinalOrmDemoActivity.java

01
package com.devchina.ormdemo;
02
 
03
import java.util.Date;
04
import java.util.List;
05
 
06
import net.tsz.afinal.FinalActivity;
07
import net.tsz.afinal.FinalDb;
08
import net.tsz.afinal.annotation.view.ViewInject;
09
import android.os.Bundle;
10
import android.util.Log;
11
import android.widget.TextView;
12
 
13
public class AfinalOrmDemoActivity extends FinalActivity {
14
    
15
    
16
    @ViewInject(id=R.id.textView) TextView textView; //这里使用了afinal的ioc功能,以后将会讲到
17
    
18
    @Override
19
    public void onCreate(Bundle savedInstanceState) {
20
        super.onCreate(savedInstanceState);
21
        setContentView(R.layout.main);
22
        
23
        FinalDb db = FinalDb.create(this);
24
        
25
        User user = new User();
26
        user.setEmail("afinal@tsz.net");
27
        user.setName("探索者");
28
        user.setRegisterDate(new Date());
29
        
30
        db.save(user);
31
        
32
        List<User> userList = db.findAll(User.class);//查询所有的用户
33
        
34
        Log.e("AfinalOrmDemoActivity", "用户数量:"+ (userList!=null?userList.size():0));
35
        
36
        textView.setText(userList.get(0).getName()+":"+user.getRegisterDate());
37
    }
38
}
很简单吧,就一个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配置一下:

01
package com.devchina.ormdemo;
02
 
03
import java.util.Date;
04
 
05
import net.tsz.afinal.annotation.sqlite.Table;
06
 
07
@Table(name="user_test")
08
public class User {
09
    
10
    private int id;
11
    private String name;
12
    private String email;
13
    private Date registerDate;
14
    private Double money;
15
&

补充:移动开发 , Android ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,