GreenDao的基本使用

1、配置


1.1 在project的Gradle中配置:

buildscript {

repositories {

         jcenter()

          mavenCentral()// 添加这一行

}

dependencies {

        classpath'com.android.tools.build:gradle:2.3.3'

        classpath'org.greenrobot:greendao-gradle-plugin:3.2.2' // 添加这一行

        // NOTE: Do not place your application dependencies here; they belong

        // in the individual module build.gradle files

}

}

allprojects {

        repositories {

               jcenter()

        }

}

1.2 在app的Gradle中配置:

applyplugin:'com.android.application'

applyplugin:'org.greenrobot.greendao'// 添加这一行

dependencies {

        compile'org.greenrobot:greendao:3.2.2'// 添加依赖

}

1.3 在app的Gradle配置数据库版本等信息

greendao {

          schemaVersion 1 // 指定数据库schema版本号,迁移等操作会用到;

          daoPackage 'com.greendao.gen'  //dao的包名,包名默认是entity所在的包;

          targetGenDir 'src/main/java'  //生成数据库文件的目录;

}

2、在项目中定义实体类


# User.java

@Entity

public classUser {

        @Id

        private long id;

        @Property(nameInDb="USERNAME")

        @NotNull

        private String name;

        @Unique

        private String mobile;

        private int gender;

        private int age;

        private Date birthday;

        @Transient

        private String remarks; 

}


注解:

@Entity   标识实体类,greenDAO会映射成sqlite的一个表,表名为实体类名的大写形式

@Id 标识主键,该字段的类型为long或Long类型,autoincrement设置是否自动增长

@Property       标识该属性在表中对应的列名称, nameInDb设置名称

@Transient      标识该属性将不会映射到表中,也就是没有这列

@NotNull         设置表中当前列的值不可为空

@Convert         指定自定义类型(@linkPropertyConverter)

@Generated   greenDAO运行所产生的构造函数或者方法,被此标注的代码可以变更或者下次运行时清除

@Index    使用@Index作为一个属性来创建一个索引;定义多列索引(@link Entity#indexes())

@JoinEntity     定义表连接关系

@JoinProperty         定义名称和引用名称属性关系

@Keep     注解的代码段在GreenDao下次运行时保持不变

         1.注解实体类:默认禁止修改此类

         2.注解其他代码段,默认禁止修改注解的代码段

@OrderBy        指定排序

@ToMany         定义与多个实体对象的关系

@ToOne  定义与另一个实体(一个实体对象)的关系

@Unique 向数据库列添加了一个唯一的约束

定义好了之后按ctrl+F9(或者工具栏build下面的Make Project)对项目进行重新构建,在daoPackage的目录下就会自动生成代码

3、使用


# App.java

public class App extends Application {

private DaoMaster.DevOpenHelper mHelper;

private SQLiteDatabase db;

private DaoMaster mDaoMaster;

private DaoSession mDaoSession;

public static App instances;

public static App getInstances() {

           return instances;

}

@Override

public voidonCreate() {

            super.onCreate();

            instances=this;

            setDatabase();

}

/**

* 设置greenDao

*/

private void setDatabase() {

// 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。

// 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。

// 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。

// 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。

mHelper=new DaoMaster.DevOpenHelper(this,"myproject-db", null);

db=mHelper.getWritableDatabase();

// 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。

mDaoMaster=new DaoMaster(db);

mDaoSession=mDaoMaster.newSession();

}

public DaoSession getDaoSession() {

       return mDaoSession;

}

public SQLiteDatabase getDb() {

         return db;

}

}


# MainActivity.java

获取UserDao对象:

UserDao mUserDao = MyApplication.getInstances().getDaoSession().getUserDao(); 

        User mUser=new User((long)1,"豆浆油条","18601952581",1,28,TimeUtils.strToDate("1990-01-01"));

        mUserDao.insertOrReplace(mUser);//添加一个

         mUserDao.deleteByKey(id);   // 根据ID删除

         mUserDao.deleteAll();    // 删除所有

         User mUser=new User((long)1,"煎饼果子","18601952581",1,28,TimeUtils.strToDate("1990-09-23"));

         mUserDao.update(mUser);

List<users>=mUserDao.loadAll();    // 查询所有

User mUser =mUserDao.loadByRowId(id);   // 根据ID查询一条

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容

  • 一、关于greenDAO greenDAO应该算是当前最火的数据库开源框架了,它是一个将对象映射到SQLite数据...
    当幸福来敲门58阅读 13,867评论 3 19
  • GreenDao 介绍:greenDAO是一个对象关系映射(ORM)的框架,能够提供一个接口通过操作对象的方式去操...
    小董666阅读 731评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 一.背景 之前用dbFlow,但是因为某些原因不适合所有机型,所以准备用GreenDao,所以现在写篇文章记录一下...
    我是大雄阅读 746评论 0 0
  • CSDN同步更新:http://blog.csdn.net/bskfnvjtlyzmv867/article/de...
    Mr丶sorrow阅读 1,698评论 1 0