Android 数据库框架OrmLite的使用(一)
在这里记录下最基本的用法,官网上可了解相关的介绍。
1、下载OrmLite jar
在下载android的:ormlite-android-4.48.jar和ormlite-core-4.48.jar,放在你项目的libs目录下。
2、编写Bean类
package com.example.ormlite.bean; import java.util.Collection; import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.field.ForeignCollectionField;
import com.j256.ormlite.table.DatabaseTable; @DatabaseTable(tableName="tb_user") //表明这是数据库中的一张表
public class User {
@DatabaseField(generatedId=true) //generatedId表示id为主键切自动生成
private int id;
@DatabaseField(columnName="name") //columnName的值为该字段在数据库表中的列名
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;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", desc=" + desc + "]";
}
}
3.编写Dao类
package com.example.ormlite.db; import java.sql.SQLException; import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory; import com.example.ormlite.bean.User;
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;
/**
* 编写DAO类
* 原生的数据库操作,需要继承SQLiteOpenHelper,这里我们需要继承OrmLiteSqliteOpenHelper(间接继承了SQLiteOpenHelper)
* @author Administrator
*
*/
public class DatabaseHelper extends OrmLiteSqliteOpenHelper{
private static final String TABLE_NAME="sqlite-test.db";
private static DatabaseHelper instance; //userDao,每张表对应一个
private Dao<User,Integer> userDao;
public 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();
}
} /**
* 单例获取该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
* 我们会有很多表,每个表一般我们都会单独写个Dao用于操作,这里为了简单我并没有抽取出来,直接写在helper中,比如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;
}
}
4.测试
关于单元测试的配置可参考Android Junit测试框架
package com.example.ormlite.test; import java.sql.SQLException;
import java.util.List; import android.test.AndroidTestCase;
import android.util.Log; import com.example.ormlite.bean.User;
import com.example.ormlite.dao.UserDao;
import com.example.ormlite.db.DatabaseHelper; public class OrmLiteDbTest extends AndroidTestCase{
public void testAddUser(){
// User u1=new User("yanqiong", "developer");
// DatabaseHelper helper=DatabaseHelper.getHelper(getContext());
// try {
// helper.getUserDao().create(u1);
// u1=new User("yanqiong2", "developer");
// helper.getUserDao().create(u1);
// u1=new User("yanqiong3", "developer");
// helper.getUserDao().create(u1);
// u1=new User("yanqiong4", "developer");
// helper.getUserDao().create(u1);
//
// testList();
// } catch (SQLException e) {
// e.printStackTrace();
// } User u1=new User("yanqiong5", "developer");
UserDao userDao=new UserDao(getContext());
userDao.add(u1); } public void testList() {
DatabaseHelper helper=DatabaseHelper.getHelper(getContext());
User u1=new User("yanqiong-android", "developer");
u1.setId(2);
List<User> users;
try {
users = helper.getUserDao().queryForAll();
Log.i("OrmLiteDbTest", users.toString());
} 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());
User u1=new User("yanqiong-android", "developer");
u1.setId(3);
try {
helper.getUserDao().update(u1);
} catch (SQLException e) {
e.printStackTrace();
}
}
}
规范的写法请参考Android 数据库框架OrmLite的使用(二)
Android 数据库框架OrmLite的使用(一)的更多相关文章
- Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的, ...
- Android 数据库框架ormlite
Android 数据库框架ormlite 使用精要 前言 本篇博客记录一下笔者在实际开发中使用到的一个数据库框架,这个可以让我们快速实现数据库操作,避免频繁手写sql,提高我们的开发效率,减少出错的机 ...
- Android数据库框架-----ORMLite关联表的使用
上一篇已经对ORMLite框架做了简单的介绍:Android数据库框架-----ORMLite 的基本用法~~本篇将介绍项目可能会使用到的一些用法,也为我们的使用ORMLite框架总结出一个较合理的用 ...
- Android数据库框架-----ORMLite 的基本用法
ORMLite 是一款非要流行的Android平台上的数据库框架,性能优秀,代码简洁: 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完善:4.文档全面. 缺点:1.基于反射,效率较低(本 ...
- Android 数据库框架OrmLite的使用(二)
前面说了OrmLite的基本使用,现在说下更规范的做法以及常用的一些功能. 1.DatabaseHelper package com.example.ormlite.db; import java.s ...
- Android数据库框架-ORMLite
参考资料 Android ORMLite 框架的入门用法 Android 快速开发系列 ORMLite 框架最佳实践 添加依赖 compile 'com.j256.ormlite:ormlite-an ...
- Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite
Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射 ...
- Android 数据库框架总结(转)
转自 http://blog.csdn.net/da_caoyuan/article/details/61414626 一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完 ...
- Android 数据库框架总结,总有一个适合你!
一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完善:4.文档全面.缺点:1.基于反射,效率较低(本人还没有觉得效率低):2.缺少中文翻译文档 jar包 地址:http: ...
随机推荐
- Java json串生成及转bean
package com; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import j ...
- Java中堆内存和栈内存详解
Java把内存分成两种,一种叫做栈内存,一种叫做堆内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,java就在栈中为这个变量分配内存空间 ...
- 纯jQuery-添加/修改/删除 标签,属性
<h1>通过学习<精彩绝伦的jQuery>与W3C,大致了解JQuery的一些方法.</h1> PS:需要有一些前置条件,比如JQuery源代码,比如html就要有 ...
- windows或mac上对iOS设备截图
1.需要在设备上安装插件“设置”--“开发者”的选项 2.启动"com.apple.mobile.screenshotr"服务 3.和设备scoket通讯,拿到截图.
- SQLPrompt 7.2发布
SQLPrompt 7.2发布 下载地址:http://www.red-gate.com/products/sql-development/sql-prompt/ 红门的热门产品SQLPrompt 发 ...
- SQL Server 连接问题案例解析(1)
SQL Server 连接问题案例解析(1) 转载自:http://blogs.msdn.com/b/apgcdsd/archive/2015/04/27/sql.aspx?CommentPosted ...
- 用"hosting.json"配置ASP.NET Core站点的Hosting环境
通常我们在 Prgram.cs 中使用硬编码的方式配置 ASP.NET Core 站点的 Hosting 环境,最常用的就是 .UseUrls() . public class Program { p ...
- FLEX布局的一些问题和解决方法
前言 露珠最近研究了一下flex的布局方式,发现项w3c推出的这套布局解决方案对于日益复杂的前端开发布局来说是确实是一利器,并且在不同的屏幕上实现了真正的响应式布局:不再单纯地依赖百分比和float的 ...
- NoSQL初探之人人都爱Redis:(1)Redis简介与简单安装
一.NoSQL的风生水起 1.1 后Web2.0时代的发展要求 随着互联网Web2.0网站的兴起,传统的关系数据库在应付Web2.0网站,特别是超大规模和高并发的SNS类型的Web2.0纯动态网站已经 ...
- [.net 面向对象程序设计进阶] (23) 团队开发利器(二)优秀的版本控制工具SVN(上)
[.net 面向对象程序设计进阶] (23) 团队开发利器(二)优秀的版本控制工具SVN(上) 本篇导读: 上篇介绍了常用的代码管理工具VSS,看了一下评论,很多同学深恶痛绝,有的甚至因为公司使用VS ...