主页: https://github.com/greenrobot/greenDAO


配置: 添加以下依赖
* compile 'de.greenrobot:greendao:2.1.0'
* compile
'de.greenrobot:greendao-generator:2.1.0'


优点:
* 性能最大化,内存开销最小化
* 易于使用的API
* 为Android进行高度优化



重要类

DaoMaster:它保存了sqlitedatebase对象以及操作DAO
classes(注意:不是对象)。其提供了一些创建和删除table的静态方法,其内部类OpenHelper和DevOpenHelper实现了SQLiteOpenHelper并创建数据库的框架。

DaoSession:会话层。操作具体的DAO对象(注意:是对象),比如各种getter方法。

XXXDao:实际生成的某某DAO类,通常对应具体的java类,比如NoteDao等。其有更多的权限和方法来操作数据库元素。

XXXEntity:持久的实体对象。通常代表了一个数据库row的标准java
properties。


使用步骤

1.创建自定义的DAOGenerater,指定数据库相关配置并生成相关类

import de.greenrobot.daogenerator.DaoGenerator;
import de.greenrobot.daogenerator.Entity;
import de.greenrobot.daogenerator.Schema; /**
* Description:帮助生成操作数据的一些Java类 */ public class CustomHelper { public static void main(String[] args) throws Exception {
//第一个参数表示数据库版本号,
//如果发生变更会导致数据库更新的操作被调用(如果不修改生成的DaoMaster中的方法
//升级默认操作是删除所有表并重新建表)
//第二个参数是生成的DAO类的包路径
Schema schema = new Schema(1, "com.itheima.greendao.db"); // 创建表,参数为表名
Entity entity = schema.addEntity("Info");
// 为表添加字段
entity.addIdProperty().primaryKey().autoincrement(); //自增长id为主键
entity.addStringProperty("name").notNull();//非null字段
entity.addIntProperty("age");//Int类型字段
entity.addStringProperty("tel");// String类型字段 // 生成数据库相关类
//第二个参数指定生成文件的本次存储路径,AndroidStudio工程指定到当前工程的java路径
new DaoGenerator().generateAll(schema,
"D:\\Android\\code-as\\Aandroid56\\DataBase\\greendao\\src\\main\\java");
} }

2.在Application中通过DaoMaster.DevOpenHelper初始化数据库

// 该初始化过程最好放在Application中进行,避免创建多个Session
private void setupDatabase() {
// 通过 DaoMaster 的内部类 DevOpenHelper创建数据库
// 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表
/**
* @param context : Context
* @param name : 数据库名字
* @param factory : CursorFactroy
*/
DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this, "student.db", null);
// 获取数据库
SQLiteDatabase database = helper.getWritableDatabase();
// 获取DaoMaster
DaoMaster daoMaster = new DaoMaster(database);
// 获取Session
DaoSession daoSession = daoMaster.newSession();
// 获取对应的表的DAO对象
InfoDao dao = daoSession.getInfoDao();}

3.获取数据库的DAO对象,即可进行增删改查的操作

        // 增
dao.insert(new Info(2l,"张三",18,"119"));
// 删
dao.deleteByKey(1L);
// 改
dao.update(new Info(3L, "赵琦", 78, "18812348888")); // 查
QueryBuilder<Info> builder = dao.queryBuilder();
List<Info> build = builder.list();
for(Info info:build){
Log.e("MainActivity",info.toString());
}

数据库开源框架之GreenDAO的更多相关文章

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

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

  2. Android 轻量级ORM数据库开源框架ActiveAndroid 源码分析

    ActiveAndroid 项目地址在https://github.com/pardom/ActiveAndroid 关于他的详细介绍和使用步骤 可以看下面两篇文章: https://github.c ...

  3. 数据库开源框架ormlite

    今天听说了ORM框架ORMLITE,特地去了解了一下. 该框架可以使用注解方式来生成数据库表,还封装了常用的数据库操作. 类似J2EE的HIBERNATE框架对数据库的处理. 省去了书写建表语句的麻烦 ...

  4. 数据库开源框架之litepal

    主页: [https://github.com/LitePalFramework/LitePal](https://github.com/LitePalFramework/LitePal) 中文文档地 ...

  5. 数据库开源框架之sqlcipher加密数据库

    访问github链接:https://github.com/sqlcipher/android-database-sqlcipher 访问 http://sqlcipher.net/sqlcipher ...

  6. 数据库开源框架之ormlite

    主页: http://ormlite.com/ 配置: 添加以下依赖 * compile 'com.j256.ormlite:ormlite-android:4.48' * compile 'com. ...

  7. 开源框架GreenDao的操作

    1.为什么需要GreenDao?Google原生API不方便 @1手动组拼SQL语句 @2需要自己写操作数据库代码 @3不能把数据库中的数据映射成对象 @4没有实现关联查询 2.GreenDao是什么 ...

  8. IT观察】网络通信、图片显示、数据库操作……Android程序员如何利用开源框架

    每个Android 程序员都不是Android应用开发之路上孤军奋战的一个人,GitHub上浩如烟海的开源框架或类库就是前人为我们发明的轮子,有的轮子能提高软件性能,而有的轮子似乎是以牺牲性能为代价换 ...

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

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

随机推荐

  1. python将list元素转为数字

    mask_x = ['11', '12', 13'] 方法1:for循环遍历 mask_x = [int(x) for x in mask_x] 方法2:map迭代 mask_x = list(map ...

  2. 6、SSH远程管理服务实战

    1.SSH基本概述 SSH是一个安全协议,在进行数据传输时,会对数据包进行加密处理,加密后在进行数据传输.确保了数据传输安全.那SSH服务主要功能有哪些呢? 1.提供远程连接服务器的服务. 2.对传输 ...

  3. vue中 localStorage的使用方法(详解)

    vue中实现本地储存的方法:localStorage,在HTML5中,新加入了一个localStorage特性,这个特性主要是用来作为本地存储来使用的,解决了cookie存储空间不足的问题(cooki ...

  4. 寒武纪C++日常实习生面经(其他人面试题)

    1.C++继承方式? 答:public,protected,private三种继承方式和虚继承一共四种. 派生类可以继承定义在基类中的成员,但是派生类的成员函数不一定有权访问从基类继承而来的成员. 派 ...

  5. ad 拼板

    随着整个电子产业的不断发展,电子行业的很多产品都已经有完善的上下游配套企业.从一个成熟产品的方案设计,外观设计,加工制造,装配测试,包装,批发商渠道等等,这样的一条产业链在特定的环境就这样自然地生成. ...

  6. 【获取url 问号后参数】防中文乱码

    function getQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&] ...

  7. 基于VS2017C++的窗口编写

    自从转专业学习计算机后就想写一个简单的有点意义的东西,没有真正接触计算机之前,一直觉得写一个界面什么的很简单.但是现在我都快学了接近一年了才正式自己学习一节界面开发.我想哭-- 我现在学习的是C++窗 ...

  8. selenium设置Chrome浏览器不出现通知,设置代理IP

    from selenium import webdriver PROXY = "" chrome_options = webdriver.ChromeOptions() prefs ...

  9. SQL语句 case ... when

    select 字段A, 字段B, CASE WHEN t.operate = 1 then 'aa'WHEN t.operate = 2 then 'bb'WHEN t.operate = 3 the ...

  10. ESP8266—“ICACHE_FLASH_ATTR”宏

    问:ESP8266_NONOS_SDK中ICACHE_FLASH_ATTR宏的用途是什么?我看到它取决于ICACHE_FLASH,但我不知道何时应该定义该符号.什么时候需要包括它?答:对于ESP826 ...