一、创建DataBase

//使用 Singleton 避免產生多個實例(instance),要注意 thread safe 這邊使用雙重鎖定(Double-checked locking)
使用 TableUtils 類別建立及刪除表格 //第一步继承 OrmLiteSqliteOpenHelper
public class DatabaseHelper extends OrmLiteSqliteOpenHelper { //版本号
private static final int DATABASE_VERSION = 1;
//版本名
private static final String DATABASE_NAME = "Demo";
//单例
private static DatabaseHelper instance; private DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
} //运用单例,加上双层线程锁,避免多创建DataBase
public static synchronized DatabaseHelper getHelper(Context context) {
context = context.getApplicationContext();
if (instance == null) {
synchronized (DatabaseHelper.class) {
if (instance == null)
instance = new DatabaseHelper(context);
}
}
return instance;
} //删除并重新创建
@Override
public void onUpgrade(SQLiteDatabase database, ConnectionSource connectionSource, int oldVersion, int newVersion) {
try {
TableUtils.dropTable(connectionSource, User.class, true);
TableUtils.dropTable(connectionSource, Group.class, true);
onCreate(database, connectionSource);
} catch (SQLException e) {
e.printStackTrace();
}
} //创建 表格
@Override
public void onCreate(SQLiteDatabase database, ConnectionSource connectionSource) {
try {
TableUtils.createTable(connectionSource, User.class);
TableUtils.createTable(connectionSource, Group.class);
} catch (SQLException e) {
e.printStackTrace();
}
}
}

DataBaseHelper

二、创建相应的JavaBean

public class User {
//注意事项:一定要加上@DatabaseField 说明这是表中的字段,这语句就是sql语句中设定主键,外键之类的。。。
@DatabaseField(generatedId = true)
private int id;
@DatabaseField
private String name;
@DatabaseField
private String psd; 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 getPsd() {
return psd;
} public void setPsd(String psd) {
this.psd = psd;
}
}

User

三、创建对DataBase的操作(这里创建操作的泛型,就是所有Dao类型都能使用)

//承接DatBaseHelper
....
//参数是Class类型
private HashMap<String,RuntimeExceptionDao> mRuntimeDaos = new HashMap<>(); public RuntimeExceptionDao getRuntimeDao(Class bean){ RuntimeExceptionDao dao = null;
String className = bean.getSimpleName();
//防止重新创建Dao
if (mRuntimeDaos.containsKey(className)){
dao = mRuntimeDaos.get(className);
}
else {
//重要的地方,如何创建Dao
dao = super.getRuntimeExceptionDao(bean);
}
return dao;
}

DataBase

四、创建对应的Dao(处理JavaBean与DataBase之间的操作)

public class UserDao {
private RuntimeExceptionDao mRuntimeDao;
//构造方法中获取Dao,用来操作数据库
public UserDao(Context context) {
DataBaseHelper dataBaseHelper = DataBaseHelper.getHelper(context);
mRuntimeDao = dataBaseHelper.getRuntimeDao(User.class);
}
//添加一个User到数据库
public void createUser(User user){
mRuntimeDao.createOrUpdate(user);
}
//从数据库中检索id为?的user
public List<User> queryUser(int id){
List<User> user = null;
try {
user = mRuntimeDao.queryBuilder().where().eq("id",id).query();
} catch (SQLException e) {
e.printStackTrace();
}
return user;
}
//清除数据库
public void clear(){
mRuntimeDao.delete(mRuntimeDao.queryForAll());
}
}

UserDao

五、ORMLite外键引用

创建一个Article类,需要知道这个Article所属的User,那么该怎么办。一般的方法,就是放入这个User的id,但是OrmLite可以放入整个User,这才是正确的面向对象程序。

所以要这么写:

public class Article {
@DatabaseField(generatedId = true)
private int id;
@DatabaseField
private String title;
@DatabaseField
private String content;
//声明这列为外键,不同于常规的数据库 外键设置的是User的id,这里直接将User设定为外键
@DatabaseField(canBeNull = true,foreign = true,columnName = "user_id")
private User user; public String getContent() {
return content;
} public void setContent(String content) {
this.content = content;
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getTitle() {
return title;
} public void setTitle(String title) {
this.title = title;
} public User getUser() {
return user;
} public void setUser(User user) {
this.user = user;
}
}

Article

public class ArticleDao {
private RuntimeExceptionDao mRuntimeDao;
private DataBaseHelper mDataBaseHelper;
//构造方法中获取Dao,用来操作数据库
public ArticleDao(Context context) {
mDataBaseHelper = DataBaseHelper.getHelper(context);
mRuntimeDao = mDataBaseHelper.getRuntimeDao(Article.class);
}
//添加一个Article到数据库
public void createUser(Article article){
mRuntimeDao.createOrUpdate(article);
}
//从数据库中检索id为?的Article,经过测试发现 只能获取到User的id,其他内容都是无法获取的
public Article queryArticle(int id){
Article article = null;
article = (Article) mRuntimeDao.queryForId(id);
return article;
}
//所以需要用该方法
public Article getArticleWithUser(int id){
Article article = queryArticle(id);
//获取到的article并没有User这个对象的内容,需要经过这一层赋值。
mDataBaseHelper.getRuntimeDao(User.class).refresh(article.getUser());
return article;
}
//根据user对象获取全部的Article
public List<Article> getArticles(int userId){
List<Article> articles = null;
try {
//发现userId的赋值跟int赋值一样
articles = mRuntimeDao.queryBuilder().where().eq("user_id",userId).query();
} catch (SQLException e) {
e.printStackTrace();
}
return articles;
}
//清除数据库
public void clear(){
mRuntimeDao.delete(mRuntimeDao.queryForAll());
}

ArticleDao

2、在user属性的注解上:@DatabaseField(canBeNull = true, foreign = true, columnName = "user_id", foreignAutoRefresh = true)

添加foreignAutoRefresh =true,这样;当调用queryForId时,拿到Article对象则直接携带了user;

六:关联一个集合

每个User关联一个或多个Article,如果我在User中声明一个Collection<Article> articles,我能否在查询User的时候,一并能够获取到articles的值呢?

在User中添加如下属性,且注解如下:

@ForeignCollectionField
private Collection<Article> articles;

测试代码

User user = new UserDao(getContext()).get(1);
L.e(user.getName());
if (user.getArticles() != null)
for (Article article : user.getArticles())
{
L.e(article.toString());
}

User关联多个Article

注:id的自增是从1开始的 0 0

简便数据库——ORMLite框架的更多相关文章

  1. Android—Ormlite框架简单的操作数据库

    大家在Android项目中或多或少的都会使用数据库,为了提高我们的开发效率,当然少不了数据库ORM框架了,尤其是某些数据库操作特别频繁的app:本篇博客将详细介绍ORMLite的简易用法. 下面开始介 ...

  2. android数据库持久化框架, ormlite框架,

    前言 Android中内置了SQLite,但是对于数据库操作这块,非常的麻烦.其实可以试用第3方的数据库持久化框架对之进行结构上调整, 摆脱了访问数据库操作的细节,不用再去写复杂的SQL语句.虽然这样 ...

  3. Android ORMLite 框架的入门用法

    大家在Android项目中或多或少的都会使用数据库,为了提高我们的开发效率,当然少不了数据库ORM框架了,尤其是某些数据库操作特别频繁的app:本篇博客将详细介绍ORMLite的简易用法. 下面开始介 ...

  4. 数据库开源框架GreenDao的使用解析

    数据库开源框架GreenDao的使用解析 1,GreenDao概述 1),greenDao是一个当下十分火热的数据库开源框架,或者说是一个帮助Android开发者将数据存到SQLite中的一个开源项目 ...

  5. android端的ormlite框架

    安卓端有很多优秀的数据库框架来操作sqlite,如ormlite框架,这个框架可以用来实现表到对象的解析和转化. 使用: 首先去官网下载两个jar包,core和android(如果在安卓端开发的话), ...

  6. [开源].NET数据库访问框架Chloe.ORM

    扯淡 13年毕业之际,进入第一家公司实习,接触了 EntityFramework,当时就觉得这东西太牛了,访问数据库都可以做得这么轻松.优雅!毕竟那时还年轻,没见过世面.工作之前为了拿个实习机会混个工 ...

  7. 基于MyBatis的数据库切分框架,可实现数据的水平切分和垂直切分。 http://www.makersoft.org

    https://github.com/makersoft/mybatis-shards MyBatis-Shards 专业的MyBatis数据库切分框架 MyBatis Shards简介 MyBati ...

  8. [iOS]数据库第三方框架FMDB详细讲解

    [iOS]数据库第三方框架FMDB详细讲解 初识FMDB iOS中原生的SQLite API在进行数据存储的时候,需要使用C语言中的函数,操作比较麻烦.于是,就出现了一系列将SQLite API进行封 ...

  9. “Zhuang.Data”轻型数据库访问框架(二)框架的入口DbAccessor对象

    目录: “Zhuang.Data”轻型数据库访问框架(一)开篇介绍 “Zhuang.Data”轻型数据库访问框架(二)框架的入口DbAccessor对象 先来看一段代码 DbAccessor dba ...

随机推荐

  1. YUI Array 之each| forEach(遍历)

    1. yui-each原码: 遍历YArray.each = YArray.forEach = Lang._isNative(Native.forEach) ? function (array, fn ...

  2. 移动web前端的一些硬技能(二)动手前必须掌握的基本常识

    记得刚开始接触移动端web的时候,书和网上的资料都不多,查起来很费劲,现在比以前要好很多了,可是还是会有一些刚接触移动端的朋友会问我一些我最初会遇到的问题,或许是书本写的并不那么重,也或许是这些知识写 ...

  3. popup

    http://vast-engineering.github.com/jquery-popup-overlay/ http://photoswipe.com/

  4. WordPress插件制作笔记(二)---Second Plugins Demo

    1->插件演示代码:下载地址:http://pan.baidu.com/s/1gd1lFlL 在 wordpress/wp-content/plugins/ 目录下 新建一个文件夹取名为seco ...

  5. UPX和WinUpack压缩壳的使用和脱法 - 脱壳篇06

    UPX和WinUpack压缩壳的使用和脱法 - 脱壳篇06 让编程改变世界 Change the world by program 今天小甲鱼给大家介绍两款压缩壳:UPX和WinUpack. UPX是 ...

  6. 我是菜鸟,我怕谁--hdu2520

    我是菜鸟,我怕谁 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  7. Delphi之通过代码示例学习XML解析、StringReplace的用法(异常控制 good)

    *Delphi之通过代码示例学习XML解析.StringReplace的用法 这个程序可以用于解析任何合法的XML字符串. 首先是看一下程序的运行效果: 以解析这样一个XML的字符串为例: <? ...

  8. FFmpeg深入分析之零-基础 <第一篇>

    FFmpeg是相当强大的多媒体编解码框架,在深入分析其源代码之前必须要有基本的多媒体基础知识,否则其源代码会非常晦涩难懂.本文将从介绍一些基本的多媒体只是,主要是为研读ffmpeg源代码做准备,比如一 ...

  9. unity3d 导出 Excel

    我在unity里需要导出成Excel格式,试了一些方法,其中用c#的com组件的我还没成功不知道该怎么在unity里调用,(如果哪位大哥用别的方法在unity里成功了,可以交流下,最好给我一个小dem ...

  10. perl HTML::TreeBuilder::XPath

    HTML::TreeBuilder::XPath 添加XPath 支持HTML::TreeBuilder use HTML::TreeBuilder::XPath;   my $tree= HTML: ...