一、创建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. Servlet开发(二)

    一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...

  2. js特殊字符转义

    点的转义:. ==> \\u002E 美元符号的转义:$ ==> \\u0024 乘方符号的转义:^ ==> \\u005E 左大括号的转义:{ ==> \\u007B 左方括 ...

  3. ZendFramework 环境部署

    查看源码 int_autoloader.php 文件中,发现应用了一个 AutoloaderFactory 的命名空间,路径写得是相对路径,所以需要在 php.ini 中定义一个 inclde_pat ...

  4. PHP读取EXCEL时写入数据乱码解决办法

    第一步排除excel读取的数据是不是乱码 EXCEL读取时经常会出现乱码,而我们常用的字符集是UTF-8 ,GB2312(GBK) ,这就需要对编码进行转换,但是又不能对纯数字和英文字符转换,否则会乱 ...

  5. Octorber 21st

    Octorber 21st Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  6. Socket 编程示例(二)

    利用晚上这点闲暇时间,写了一个Socket通信的小实例,该实例包含服务器端和客户端.其基本工作流程是:当服务器启动服务以后,客户端进行连接,如果连接成功,则用户可以在发送消息框中输入待发送的消息,然后 ...

  7. UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming<Problem F>

    F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  8. UVA_Cubic Eight-Puzzle UVA 1604

    Let's play a puzzle using eight cubes placed on a 3 x 3 board leaving one empty square.Faces of cube ...

  9. House Robber 解答

    Question You are a professional robber planning to rob houses along a street. Each house has a certa ...

  10. 04747_Java语言程序设计(一)_第1章_Java语言基础

    二进制0b开头 八进制0开头 十六进制0x开头 package com.jacky; public class Aserver { public static void main(String arg ...