1.创建一个实体类

1
Entity note = schema.addEntity("Note");

默认表名就是类名,也可以自定义表名

1.dao.setTableName("NoteList");

greenDAO会自动根据实体类属性创建表字段,并赋予默认值。例如在数据库方面的表名和列名都来源于实体类名和属性名。默认的数据库名称是大写使用下划线分隔单词,而不是在Java中使用的驼峰式大小写风格。例如,一个名为“CREATIONDATE”属性将成为一个数据库列“CREATION_DATE”。

设置一个自增长ID列为主键:

1.dao.addIdProperty().primaryKey().autoincrement();

设置其他各种类型的属性:

1
2
3
dao.addIntProperty("cityId");
dao.addStringProperty("infoType").notNull();//非null字段
dao.addDoubleProperty("Id");

在生成的实体类中,int类型为自动转为long类型。

如果在编译过程中出现以下错误,那么有可能是主键的类型错误所致:

1.java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String

在使用greenDAO时,一个实体类只能对应一个表,目前没法做到一个表对应多个实体类,或者多个表共用一种对象类型。后续的升级也不会针对这一点进行扩展。

(二)表的增删改查

增删改查相当方便,完全的面向对象,不需要涉及到任何的sql语言。

1.查询

范例1:查询某个表是否包含某个id:

1.public boolean isSaved(int ID)
2.{
3.QueryBuilder<SaveList> qb = saveListDao.queryBuilder();
4.qb.where(Properties.Id.eq(ID));
5.qb.buildCount().count();
6.return qb.buildCount().count() > 0 true false;
7.}

范例2:获取整个表的数据集合,一句代码就搞定!

1
2
3
4
public List<PhotoGalleryDB> getPhotoGallery()
{
    return photoGalleryDao.loadAll();// 获取图片相册
}

范例3:通过一个字段值查找对应的另一个字段值(为简便直接使用下面方法,也许有更简单的方法,尚未尝试)

01./** 通过图片id查找其目录id */
02.public int getTypeId(int picId)
03.{
04.QueryBuilder<PhotoGalleryDB> qb = photoGalleryDao.queryBuilder();
05.qb.where(Properties.Id.eq(picId));
06.if (qb.list().size() > 0)
07.{
08.return qb.list().get(0).getTypeId();
09.}
10.else
11.{
12.return -1;
13.}
14.}

范例4:查找所有第一姓名是“Joe”并且以lastname排序。

1.List joes = userDao.queryBuilder()
2..where(Properties.FirstName.eq("Joe"))
3..orderAsc(Properties.LastName)
4..list();

范例5:多重条件查询

(1)获取id为cityId并且infotype为HBContant.CITYINFO_SL的数据集合:

1.public List<CityInfoDB> getSupportingList(int cityId)
2.{
3.QueryBuilder<CityInfoDB> qb = cityInfoDao.queryBuilder();
4.qb.where(qb.and(Properties.CityId.eq(cityId),Properties.InfoType.eq(HBContant.CITYINFO_SL)));
5.qb.orderAsc(Properties.Id);// 排序依据
6.return qb.list();
7.}

(2)获取firstname为“Joe”并且出生于1970年10月以后的所有user集合:

1.QueryBuilder qb = userDao.queryBuilder();
2.qb.where(Properties.FirstName.eq("Joe"),
3.qb.or(Properties.YearOfBirth.gt(1970),
4.qb.and(Properties.YearOfBirth.eq(1970), Properties.MonthOfBirth.ge(10))));
5.List youngJoes = qb.list();

范例6:获取某列对象

1.picJsonDao.loadByRowId(picId);

2.增添/插入、修改

插入数据更加简单,也是只要一句代码便能搞定!

1.public void addToPhotoTable(Photo p)
2.{
3.photoDao.insert(p);
4.}

插入时需要new一个新的对象,范例如下:

1.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this"notes-db"null);
2.db = helper.getWritableDatabase();
3.daoMaster = new DaoMaster(db);
4.daoSession = daoMaster.newSession();
5.noteDao = daoSession.getNoteDao();
6.Note note = new Note(null, noteText, comment, new Date());
7.noteDao.insert(note);

修改更新:

1.photoDao.insertOrReplace(photo);
2.photoDao.insertInTx(photo);

3.删除:

(1)清空表格数据

1./** 清空相册图片列表的数据 */
2.public void clearPhoto()
3.{
4.photoDao.deleteAll();
5.}

(2)删除某个对象

1.public void deleteCityInfo(int cityId)
2.{
3.QueryBuilder<DBCityInfo> qb = cityInfoDao.queryBuilder();
4.DeleteQuery<DBCityInfo> bd = qb.where(Properties.CityId.eq(cityId)).buildDelete();
5.bd.executeDeleteWithoutDetachingEntities();
6.}

参考:https://github.com/greenrobot/greenDAO/issues/34

由上可见,使用greenDAO进行数据库的增删改查时及其方便,而且性能极佳。

(三)常用方法笔记

1.在Application实现得到DaoMaster和DaoSession的方法:

01.private static DaoMaster daoMaster;
02.private static DaoSession daoSession;
03./**
04.* 取得DaoMaster
05.*
06.* @param context
07.* @return
08.*/
09.public static DaoMaster getDaoMaster(Context context)
10.{
11.if (daoMaster == null)
12.{
13.OpenHelper helper = new DaoMaster.DevOpenHelper(context, HBContant.DATABASE_NAME, null);
14.daoMaster = new DaoMaster(helper.getWritableDatabase());
15.}
16.return daoMaster;
17.}
18./**
19.* 取得DaoSession
20.*
21.* @param context
22.* @return
23.*/
24.public static DaoSession getDaoSession(Context context)
25.{
26.if (daoSession == null)
27.{
28.if (daoMaster == null)
29.{
30.daoMaster = getDaoMaster(context);
31.}
32.daoSession = daoMaster.newSession();
33.}
34.return daoSession;
35.}

2.增删改查工具类:

01.public class DBHelper
02.{
03.private static Context mContext;
04.private static DBHelper instance;
05. 
06.private CityInfoDBDao cityInfoDao;
07. 
08.private DBHelper()
09.{
10.}
11. 
12.public static DBHelper getInstance(Context context)
13.{
14.if (instance == null)
15.{
16.instance = new DBHelper();
17.if (mContext == null)
18.{
19.mContext = context;
20.}
21. 
22.// 数据库对象
23.DaoSession daoSession = HBApplication.getDaoSession(mContext);
24.instance.cityInfoDao = daoSession.getCityInfoDBDao();
25.}
26.return instance;
27.}
28. 
29./** 添加数据 */
30.public void addToCityInfoTable(CityInfo item)
31.{
32.cityInfoDao.insert(item);
33.}
34. 
35./** 查询 */
36.public List<EstateLoveListJson> getCityInfoList()
37.{
38.QueryBuilder<CityInfo> qb = cityInfoDao.queryBuilder();
39.return qb.list();
40.}
41. 
42./** 查询 */
43.public List<CityInfo> getCityInfo()
44.{
45.return cityInfoDao.loadAll();// 查找图片相册
46.}
47. 
48./** 查询 */
49.public boolean isSaved(int Id)
50.{
51.QueryBuilder<CityInfo> qb = cityInfoDao.queryBuilder();
52.qb.where(Properties.Id.eq(Id));
53.qb.buildCount().count();
54.return qb.buildCount().count() > 0 true false;// 查找收藏表
55.}
56. 
57./** 删除 */
58.public void deleteCityInfoList(int Id)
59.{
60.QueryBuilder<CityInfo> qb = cityInfoDao.queryBuilder();
61.DeleteQuery<CityInfo> bd = qb.where(Properties.Id.eq(Id)).buildDelete();
62.bd.executeDeleteWithoutDetachingEntities();
63.}
64. 
65./** 删除 */
66.public void clearCityInfo()
67.{
68.cityInfoDao.deleteAll();
69.}
70. 
71./** 通过城市id查找其类型id */
72.public int getTypeId(int cityId)
73.{
74.QueryBuilder<CityInfo> qb = cityInfoDao.queryBuilder();
75.qb.where(Properties.Id.eq(cityId));
76.if (qb.list().size() > 0)
77.{
78.return qb.list().get(0).getTypeId();
79.}
80.else
81.{
82.return 0;
83.}
84.}
85. 
86./** 多重查询 */
87.public List<CityInfo> getIphRegionList(int cityId)
88.{
89.QueryBuilder<CityInfoDB> qb = cityInfoDao.queryBuilder();
90.qb.where(qb.and(Properties.CityId.eq(cityId), Properties.InfoType.eq(HBContant.CITYINFO_IR)));
91.qb.orderAsc(Properties.Id);// 排序依据
92.return qb.list();
93.}
94.}

GreenDao 使用二的更多相关文章

  1. Android之greenDao使用

    文章大纲 一.greenDao简介二.greenDao实战三.项目源码下载四.参考文章   一.greenDao简介 1. 什么是greenDao   GreenDAO是一个开源的Android OR ...

  2. android_orm框架之greenDAO(二)

    一.概述 在上次greenDao第一篇文章中,我们对greenDao的使用步骤和基本用法给大家做了介绍,文章链接:http://www.cnblogs.com/jerehedu/p/4304766.h ...

  3. Android 数据库ORM框架GreenDao学习心得及使用总结<二>

    转:http://blog.csdn.net/xushuaic/article/details/24496191 第五篇 查询 查询会返回符合某些特定标准的实体.你可以使用原始的SQL定制查询语句,或 ...

  4. GreenDao 数据库:使用Raw文件夹下的数据库文件以及数据库升级

    一.使用Raw文件夹下的数据库文件 在使用GreenDao框架时,数据库和数据表都是根据生成的框架代码来自动创建的,从生成的DaoMaster中的OpenHelper类可以看出: public sta ...

  5. 安卓GreenDao框架一些进阶用法整理

    大致分为以下几个方面: 一些查询指令整理 使用SQL语句进行特殊查询 检测表字段是否存在 数据库升级 数据库表字段赋初始值 一.查询指令整理 1.链式执行的指令 return mDaoSession. ...

  6. Android ORM 框架之 greenDAO 使用心得

    前言 我相信,在平时的开发过程中,大家一定会或多或少地接触到 SQLite.然而在使用它时,我们往往需要做许多额外的工作,像编写 SQL 语句与解析查询结果等.所以,适用于 Android 的ORM  ...

  7. Android开源项目(二)

    第二部分 工具库 主要包括那些不错的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多媒体相关及其他. 一.依赖注入DI 通过 ...

  8. 数据库ORM框架GreenDao

    常用的数据库: 1). Sql Server2). Access3). Oracle4). Sysbase5). MySql6). Informix7). FoxPro8). PostgreSQL9) ...

  9. android高效ORM数据库框架greenDao使用

    因为项目中多处用到了数据库,需要对数据库频繁的读写操作,虽然android 自带的SQLiteOpenHelper的.这种方式比较方便易懂,但是在使用过程中需要写很多的sql语句,而且需要及时的关闭和 ...

随机推荐

  1. Android -- onMeasure()源码分析

    1,作为自定义控件最重要的三个方法之一,onMeasure()可以说是我们研究的重点,今天我们更详细的来研究一下View的onMeasure()方法和ViewGroup的onMeasure()方法 2 ...

  2. WebStorm里使用注意点

    归纳一些我在使用webstorm里遇到的问题: 1.问题:文件出现红线,如图 解决方案:可能是由于语言版本的问题,改一下版本试试 2.快捷键:http://www.cnblogs.com/yeming ...

  3. bootstrap(响应式)加减输入框

    <div class="row">  <div class="col-lg-6">    <div class="inp ...

  4. Angular4.0.0发布总览文章

    翻译自angular.io上的关于4.0.0版本发布的文章,内容主要是介绍了4.0.0版本下的改进以及接下来还会有的其他更新,4.0.0其实已经出来好多天了,截止目前都已经到了4.0.1版本了,这也是 ...

  5. 02 Learning to Answer Yes/No

    Perceptron Learning Algorithm 感知器算法, 本质是二元线性分类算法,即用一条线/一个面/一个超平面将1,2维/3维/4维及以上数据集根据标签的不同一分为二. 算法确定后, ...

  6. 学习面向对象编程OOP 第二天

    好,今天继续学习这个面向对象编程.(根据博客园 小炒花生米写的博客学习而来) 一,封装性 a.把对象的全部属性和全部服务(方法)结合在一起,形成一个不可分割的独立单元 =>对象 b.信息隐蔽,尽 ...

  7. HTML5技术实现Web图形图像处理——WebPhotoshop精简版

    WebPhotoshop精简版是利用HTML5技术在Web上实现对图形图像的处理,构建易维护.易共享.易于拓展.实时性的Web图形图像处理平台. 精简版功能包括:图形绘制.图像处理.图像操作.完整版包 ...

  8. opencv构建高斯卷积核

    关于高斯核函数可以参见阮一峰老师的日志:高斯模糊的算法 如何使用高斯核进行高斯模糊可以参见我的另一篇日志:opencv构建自定义卷积 Mat Gaussian_kernal(int kernel_si ...

  9. 解决移动端click点击问题

    下载地址:https://github.com/ftlabs/fastclick 1,为什么移动端点击会有300ms的延迟呢? 从点击屏幕上的元素到触发元素的 click 事件,移动浏览器会有大约 3 ...

  10. 事件驱动的Python实现

    EventManager事件管理类实现,大概就百来行代码左右.如果有不了事件驱动的工作原理的可以看前一篇<事件驱动的简明讲解> # encoding: UTF-8 # 系统模块 from ...