博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android 中的ORM框架
阅读量:5952 次
发布时间:2019-06-19

本文共 2217 字,大约阅读时间需要 7 分钟。

在android 中,内置了sqlite数据库,java web 中,用惯了Hibernate ,想找找android中是否也有类似的orm框架,后来在开源中国看到了orman,这是一个很不错的框架。

这个可以帮我们快捷方便的实现数据库的CURD操作。下面以Users这个用户类为例,和大家分享一下我的心得。

大家先在工程中导入orman的jar包。

这是我写的users类

package xidian.wq.entity;import java.io.Serializable;import org.orman.mapper.Model;import org.orman.mapper.ModelQuery;import org.orman.mapper.annotation.Column;import org.orman.mapper.annotation.Entity;import org.orman.mapper.annotation.PrimaryKey;import org.orman.sql.C;/** * 用户类 * @author WWF * @date 2012-12-16 下午1:22:37 */@SuppressWarnings("serial")@Entity(table="users")public class Users extends Model
implements Serializable{ @PrimaryKey//自增的话,@PrimaryKey(autoIncrement=true) @Column(name="user_id",type="int")//映射的字段名和类型,类型可以省略不写 public int userId; @Column(name = "user_name",type="text") public String userName; @Column(name="user_password",type="text") public String userPassword; @Column(name="login_time",type="text") public String loginTime; @Override public void update() { Model.execute(ModelQuery.update().from(Users.class) .set(Users.class, "user_name", userName) .set(Users.class, "user_password",userPassword) .set(Users.class, "login_time", loginTime) .where(C.eq("user_id", userId)) .getQuery()); } }

因为orman对于持久化的支持不咋符合我们的操作习惯,所以我个人比较喜欢重写其update方法,就几行代码。android中,字段尽量少,存储重要的数据。所以这个工程量较少。然后在应用启动时,要注册这个users类,在启动的Application中注册,

代码如下

Database db = new SQLiteAndroid(this, AppConfig.DATABASE_PATH+AppConfig.DATABASE_FILENAME);        MappingSession.registerDatabase(db);        //注册实体类        MappingSession.registerEntity(Users.class);        MappingSession.registerEntity(Channel.class);        MappingSession.registerEntity(RSSItem.class);        MappingSession.registerEntity(ChannelGroup.class);        MappingSession.start();

然后在任何的Activity 中就可以使用了,

Users user = new Users();//插入user.insert();//删除user.delete();//更新user.update();//查询user = Model.fetchSingle(ModelQuery.select().from(Users.class).where(C.eq("user_id", id)).getQuery(), Users.class);//查询更多List
users = Model.fetchQuery(ModelQuery.select().from(Users.class).where(C.like("user_name", "%2%")).getQuery(), Users.class);

转载于:https://www.cnblogs.com/Codenewbie/archive/2013/03/21/2973248.html

你可能感兴趣的文章
Jenkins不同job之间传递参数
查看>>
解决在Windows 2003的 IIS 6.0 中无法上传超过200K的附件以及无法下载超过4M的附件问题...
查看>>
Message和handler传递对象
查看>>
Weka算法Classifier-tree-J48源代码分析(一个)基本数据结构和算法
查看>>
如何将自己的代码自动添加版权信息[转]
查看>>
PLSQL用DBMS_JOB建立作业
查看>>
实战 SQL Server 2008 数据库误删除数据的恢复
查看>>
从函数调用来思考多态
查看>>
[Oracle]如果误删了某个数据文件,又没有被备份,能否恢复?
查看>>
Access访问错误集锦:Access关键字
查看>>
iostat命令详解
查看>>
女子监狱第一季/全集Orange Is the New Black迅雷下载
查看>>
vc中运行外部程序的方法
查看>>
[51单片机] SPI nRF24L01无线 [可以放在2个单片机里实现通信]
查看>>
面试题:在O(1)空间复杂度范围内对一个数组中前后连段有序数组进行归并排序...
查看>>
用ajax技术实现无闪烁定时刷新页面
查看>>
子进程清理
查看>>
HDU1022 Train Problem I
查看>>
微软已停止对Vista RTM(SP0)的服务支持
查看>>
Spring依赖检查
查看>>