Android ORMLite 框架的入门用法
大家在Android项目中或多或少的都会使用数据库,为了提高我们的开发效率,当然少不了数据库ORM框架了,尤其是某些数据库操作特别频繁的app;本篇博客将详细介绍ORMLite的简易用法。
下面开始介绍ORMLite的入门用法~
1、下载 ORMLite Jar
首先去ORMLite官网下载jar包,对于Android为:ormlite-android-4.48.jar 和 ormlite-core-4.48.jar ;
ps:访问不了的朋友,文章末尾会把jar、源码、doc与本篇博客例子一起打包提供给大家下载。
2、配置Bean类
有了jar,我们直接新建一个项目为:zhy_ormlite,然后把jar拷贝到libs下。
然后新建一个包:com.zhy.zhy_ormlite.bean专门用于存放项目中的Bean,首先新建一个User.Java
- package com.zhy.zhy_ormlite.bean;
- import com.j256.ormlite.field.DatabaseField;
- import com.j256.ormlite.table.DatabaseTable;
- @DatabaseTable(tableName = "tb_user")
- public class User
- {
- @DatabaseField(generatedId = true)
- private int id;
- @DatabaseField(columnName = "name")
- private String name;
- @DatabaseField(columnName = "desc")
- private String desc;
- public User()
- {
- }
- public User(String name, String desc)
- {
- this.name = name;
- this.desc = desc;
- }
- 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 getDesc()
- {
- return desc;
- }
- public void setDesc(String desc)
- {
- this.desc = desc;
- }
- }
首先在User类上添加@DatabaseTable(tableName = "tb_user"),标明这是数据库中的一张表,标明为tb_user
然后分别在属性上添加@DatabaseField(columnName = "name") ,columnName的值为该字段在数据中的列名
@DatabaseField(generatedId = true) ,generatedId 表示id为主键且自动生成
3、编写DAO类
原生的数据库操作,需要继承SQLiteOpenHelper,这里我们需要继承OrmLiteSqliteOpenHelper,看代码:
- package com.zhy.zhy_ormlite.db;
- import java.sql.SQLException;
- import android.content.Context;
- import android.database.sqlite.SQLiteDatabase;
- import com.j256.ormlite.android.apptools.OrmLiteSqliteOpenHelper;
- import com.j256.ormlite.dao.Dao;
- import com.j256.ormlite.support.ConnectionSource;
- import com.j256.ormlite.table.TableUtils;
- import com.zhy.zhy_ormlite.bean.User;
- public class DatabaseHelper extends OrmLiteSqliteOpenHelper
- {
- private static final String TABLE_NAME = "sqlite-test.db";
- /**
- * userDao ,每张表对于一个
- */
- private Dao<User, Integer> userDao;
- private DatabaseHelper(Context context)
- {
- super(context, TABLE_NAME, null, 2);
- }
- @Override
- public void onCreate(SQLiteDatabase database,
- ConnectionSource connectionSource)
- {
- try
- {
- TableUtils.createTable(connectionSource, User.class);
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- @Override
- public void onUpgrade(SQLiteDatabase database,
- ConnectionSource connectionSource, int oldVersion, int newVersion)
- {
- try
- {
- TableUtils.dropTable(connectionSource, User.class, true);
- onCreate(database, connectionSource);
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- private static DatabaseHelper instance;
- /**
- * 单例获取该Helper
- *
- * @param context
- * @return
- */
- public static synchronized DatabaseHelper getHelper(Context context)
- {
- if (instance == null)
- {
- synchronized (DatabaseHelper.class)
- {
- if (instance == null)
- instance = new DatabaseHelper(context);
- }
- }
- return instance;
- }
- /**
- * 获得userDao
- *
- * @return
- * @throws SQLException
- */
- public Dao<User, Integer> getUserDao() throws SQLException
- {
- if (userDao == null)
- {
- userDao = getDao(User.class);
- }
- return userDao;
- }
- /**
- * 释放资源
- */
- @Override
- public void close()
- {
- super.close();
- userDao = null;
- }
- }
这里我们需要继承OrmLiteSqliteOpenHelper,其实就是间接继承了SQLiteOpenHelper
然后需要实现两个方法:
1、onCreate(SQLiteDatabase database,ConnectionSource connectionSource)
创建表,我们直接使用ormlite提供的TableUtils.createTable(connectionSource, User.class);进行创建~
2、onUpgrade(SQLiteDatabase database, ConnectionSource connectionSource, int oldVersion, int newVersion)
更新表,使用ormlite提供的TableUtils.dropTable(connectionSource, User.class, true);进行删除操作~
删除完成后,别忘了,创建操作:onCreate(database, connectionSource);
然后使用单例公布出一个创建实例的方法,getHelper用于获取我们的help实例;
最后我们可能会有很多表嘛,每个表一般我们都会单独写个Dao用于操作,这里为了简单我并没有抽取出来,直接写在helper中:
比如UserDao的获取:
- /**
- * 获得userDao
- *
- * @return
- * @throws SQLException
- */
- public Dao<User, Integer> getUserDao() throws SQLException
- {
- if (userDao == null)
- {
- userDao = getDao(User.class);
- }
- return userDao;
- }
然后通过获取到的Dao就可以进行User的一些常用的操作了。
4、测试
最后是测试,我们直接创建了一个测试类进行测试~~~
- package com.zhy.zhy_ormlite.test;
- import java.sql.SQLException;
- import java.util.List;
- import com.zhy.zhy_ormlite.bean.User;
- import com.zhy.zhy_ormlite.db.DatabaseHelper;
- import android.test.AndroidTestCase;
- import android.util.Log;
- public class OrmLiteDbTest extends AndroidTestCase
- {
- public void testAddUser()
- {
- User u1 = new User("zhy", "2B青年");
- DatabaseHelper helper = DatabaseHelper.getHelper(getContext());
- try
- {
- helper.getUserDao().create(u1);
- u1 = new User("zhy2", "2B青年");
- helper.getUserDao().create(u1);
- u1 = new User("zhy3", "2B青年");
- helper.getUserDao().create(u1);
- u1 = new User("zhy4", "2B青年");
- helper.getUserDao().create(u1);
- u1 = new User("zhy5", "2B青年");
- helper.getUserDao().create(u1);
- u1 = new User("zhy6", "2B青年");
- helper.getUserDao().create(u1);
- testList();
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- public void testDeleteUser()
- {
- DatabaseHelper helper = DatabaseHelper.getHelper(getContext());
- try
- {
- helper.getUserDao().deleteById(2);
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- public void testUpdateUser()
- {
- DatabaseHelper helper = DatabaseHelper.getHelper(getContext());
- try
- {
- User u1 = new User("zhy-android", "2B青年");
- u1.setId(3);
- helper.getUserDao().update(u1);
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- public void testList()
- {
- DatabaseHelper helper = DatabaseHelper.getHelper(getContext());
- try
- {
- User u1 = new User("zhy-android", "2B青年");
- u1.setId(2);
- List<User> users = helper.getUserDao().queryForAll();
- Log.e("TAG", users.toString());
- } catch (SQLException e)
- {
- e.printStackTrace();
- }
- }
- }
简单测试了下CURD,使用AndroidTestCase记得配置下环境~~~
用起来是不是还是非常方便的,不过还是建议大家例如User的数据库操作,单独抽取出来为UserDao,如下:
- package com.zhy.zhy_ormlite.db;
- import java.sql.SQLException;
- import android.content.Context;
- import com.zhy.zhy_ormlite.bean.User;
- public class UserDao
- {
- private Context context;
- public UserDao(Context context)
- {
- this.context = context;
- }
- public void add(User user)
- {
- try
- {
- DatabaseHelper.getHelper(context).getUserDao().create(user);
- } catch (SQLException e)
- {
- }
- }//......
- }
注:ORMLite还提供了一些基类ORMLiteBaseActivity,ORMLiteBaseService之类的,便于数据库操作的,这里不做考虑,毕竟项目中很大可能自己也需要继承自己的BaseActvity之类的。
上面简单介绍了如何使用ORMLite框架,Android 快速开发系列 ORMLite 框架的使用 将对其用法进行深入的介绍。
Android ORMLite 框架的入门用法的更多相关文章
- Android—Ormlite框架简单的操作数据库
大家在Android项目中或多或少的都会使用数据库,为了提高我们的开发效率,当然少不了数据库ORM框架了,尤其是某些数据库操作特别频繁的app:本篇博客将详细介绍ORMLite的简易用法. 下面开始介 ...
- Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的, ...
- Android数据库框架-ORMLite
参考资料 Android ORMLite 框架的入门用法 Android 快速开发系列 ORMLite 框架最佳实践 添加依赖 compile 'com.j256.ormlite:ormlite-an ...
- Android数据库框架-----ORMLite 的基本用法
ORMLite 是一款非要流行的Android平台上的数据库框架,性能优秀,代码简洁: 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完善:4.文档全面. 缺点:1.基于反射,效率较低(本 ...
- Android 数据库框架OrmLite的使用(一)
在这里记录下最基本的用法,官网上可了解相关的介绍. 1.下载OrmLite jar 在下载android的:ormlite-android-4.48.jar和ormlite-core-4.48.jar ...
- Android数据库框架-----ORMLite关联表的使用
上一篇已经对ORMLite框架做了简单的介绍:Android数据库框架-----ORMLite 的基本用法~~本篇将介绍项目可能会使用到的一些用法,也为我们的使用ORMLite框架总结出一个较合理的用 ...
- android ORM框架ORMLite封装
源码:http://download.csdn.net/detail/a924571572/9415506 一.框架效率对比 由于目前公司里面android端数据的数据量基本在千条以内,所以选择了更为 ...
- android数据库持久化框架, ormlite框架,
前言 Android中内置了SQLite,但是对于数据库操作这块,非常的麻烦.其实可以试用第3方的数据库持久化框架对之进行结构上调整, 摆脱了访问数据库操作的细节,不用再去写复杂的SQL语句.虽然这样 ...
- Android 数据库框架ormlite
Android 数据库框架ormlite 使用精要 前言 本篇博客记录一下笔者在实际开发中使用到的一个数据库框架,这个可以让我们快速实现数据库操作,避免频繁手写sql,提高我们的开发效率,减少出错的机 ...
随机推荐
- 【js 编程艺术】小制作三
1.html文件 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- I/O模型浅析
引入 首先来说一下进程: 进程在就是一段执行中的代码,他是由一条条指令和数据组成的一个具有生命周期的有头有尾的实体. 进程根据权限大体上可以分为两类:用户进程 和 内核进程. 这两者的主要区别在于权限 ...
- Ubuntu 修改时区
1. 使用命令行 sudo tzselect 根据提示完成修改 2.修改~/.profile文件 添加: TZ='Asia/Shanghai'; export TZ 注销后重新登陆生效
- Mac系统安装Aircrack-ng破解wifi密码(2)
我们上一篇文章说过如何通过Aircrack-ng, 破解使用WPA/PSK加密方式的路由密码, 这一篇介绍的是使用Aircrack-ng破解使用WEP加密方式的路由密码: WEP和WPA/PSK的区别 ...
- OCR技术浅探: 语言模型(4)
由于图像质量等原因,性能再好的识别模型,都会有识别错误的可能性,为了减少识别错误率,可以将识别问题跟统计语言模型结合起来,通过动态规划的方法给出最优的识别结果.这是改进OCR识别效果的重要方法之一. ...
- 软通动力C语言机试题
#include <stdio.h> int charCount(char *str) { int iCount = 0; int i, j, k=0; char *p = str; ch ...
- IP分类以及特殊IP
一.IP分类 点分十进制数表示的IPv4 地址分成几类,以适应大型.中型.小型的网络.这些类的不同之处在于用于表示网络的位数与用于表示主机的位数之间的差别.IP地址分成五类,用字母表示: ...
- 用phpcms如何将静态页面制作成企业网站,头部加尾部
首先,先要准备好这个静态网页的源文件,如图 bs里面是一些css和js的文件,img则是放图片的,文件中的index是网页的首页 运行一下,看看 是这样的 然后打开phpcms文件,上篇博客中有提到, ...
- C# 总结const、 readonly、 static三者区别:
总结const. readonly. static三者区别: (有人问我,看似简单,我也没能立刻回答出来,总结一下,分享一下.) const:静态常量,也称编译时常量(compile-time con ...
- ACM 海贼王之伟大航路(深搜剪枝)
"我是要成为海贼王的男人!" 路飞他们伟大航路行程的起点是罗格镇,终点是拉夫德鲁(那里藏匿着"唯一的大秘宝"--ONE PIECE).而航程中间,则是各式各样的 ...