XAndrDB - Android 的 ORM 框架


GPL
Android
Java

软件简介

安卓上一个开源的ORM 数据库操作框架,安卓端的MyBatis.

AndrDB

关于编写这个框架的初衷,为的就是能在安卓中使用对象一样操作数据库,
但是一想操作数据库SQLite使用起来这么麻烦。所以结合以前的经验再加上阅读mybatis的源码。 自己写了一个’安卓端的mybatis’

使用说明:

在使用本框架之前首先 将本项目根目录下的XAndrDB.jar引入到你的项目中,然后。 在你的app的AndroidManifest.xml中配置:

<application
android:name="com.xcode.xandrdb.Session.SessionApplication"
……
>

这时候就该考虑使用问题了。

不多说,直接贴代码:

package com.xcode.xandrdb.mapper;

import com.xcode.xandrdb.User;
import com.xcode.xandrdb.annotation.Create;
import com.xcode.xandrdb.annotation.Delete;
import com.xcode.xandrdb.annotation.Insert;
import com.xcode.xandrdb.annotation.Select;
import com.xcode.xandrdb.annotation.Update;
import com.xcode.xandrdb.annotation.name;

public interface test
{
    //插入的操作
    @Insert("INSERT INTO xiaolei ('sname', 'snumber') VALUES ('xiaolei', 'xiaolei')")
    public String insert();

    //删除操作
    @Delete("delete from xiaolei where id = #{id}")
    public String delete(@name("id")int id);

    //更新操作
    @Update("UPDATE xiaolei SET sname='xiaolei2', snumber='xiaolei2' WHERE (_id=#{id})")
    public String update(@name("id")int id);

    //查询操作
    @Select("SELECT * FROM xiaolei WHERE _id = #{id}")
    public User[] select(@name("id")int id);

    //新建操作
    @Create("create table #{user.name}(_id integer primary key autoincrement,sname text,snumber text)")
    public String create(@name("user")User user);
}

这里只是定义了一系列的数据库操作action的Mapper。那我们看看怎么使用这些Mapper:

Session session = SessionFactory.getSession(new SessionConfig().setDBName("xiaolei"));
test t1 = session.getMapper(test.class);
User users[] = t1.select(1);
System.out.println(users);

是的,所有的数据库操作都必须使用Session对象,去操作。然后使用Session对象拿到mapper,内部通过动态代理操作返回你一个mapper对象,然后你操作你的mapper里面定义的方法就是在操作数据库了。

这是一个完全面向切面,使用 自定义注解+反射+动态代理
结合在一起发挥强大功能的数据库框架。