GreenDao3.0 学习笔记——导入以及注解
来源:互联网 发布:nginx root详解 编辑:程序博客网 时间:2024/06/06 04:50
前言:
本文是我自己的学习笔记,有很多地方还没有深入的了解,所以会有错误及描述不全的地方,这也是我的第一篇博客,希望得到指正,以下是我学习过程中找到的两个比较好的博客
Android ORM——初识greenDAO 3及使用greenDAO 3前应该掌握的一些知识点(一)
android greendao3.0 多表关联踩坑实践
文中对于ToOne以及ToMany两个注解没有说明,可以参考以上两个博客,基本讲的比较清楚
导入
一,在as中导入相关的包
compile'org.greenrobot:greendao:3.0.1'compile'org.greenrobot:greendao-generator:3.0.0'
二,在build.gradle中进行配置:
apply plugin: 'org.greenrobot.greendao'
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.greenrobot:greendao-gradle-plugin:3.0.0'
}
}
//设置自动生成代码的位置,说明上是可以不填,默认生成位置是build文件夹下面
//如果不加这段,就需要加上资源目录,否则编译时会找不到相关生成的class文件
greendao {
schemaVersion 1
daoPackage 'com.anye.greendao.gen'
targetGenDir 'src/main/java'
}
注解
1,@Entity
告诉代码集成器,该实体是与数据库关联的,需要生成相关代码,写完之后同步,代码自动生成
相关属性:
@nameInDb 在数据库中的名字,如不写则为实体中类名
@indexes 索引,对索引的解释自行百度
@createInDb 是否创建表,默认为true,false时不创建
@schema 指定架构,即数据库的名称,默认会生成一个数据库,如果存在多个数据库,不同数据库中的实体不能存在联系
@active //todo
注:实体必须为java,用kotlin会无法生成代码
2,@Id
标识该元素为该表的主键,可以不存在主键,主键不能重复,insert插入相同主键的实体会报错,如果不能确定,可以使用insertOrReplace方法
相关属性:
@autoincrement 设置主键自增,只有在主键是long的时候生效,设置自增会导致额外的开销,在greendao的使用方式中看不出设置自增有什么用
3,@Property
修饰该元素
相关属性:
@nameInDb 设置该元素在表中的键名,不设置时默认为元素的变量名的全大写形式(根据驼峰原则加入下划线,如:userName => USER_NAME)
4,@NotNull
该元素值不能为null,否则报错
5,@Transient
忽视该元素,即不存入数据库
6,@OrderBy
排序,该注解用于注解变量
相关属性:
@OrderBy("属性A 排序方式,属性B,属性C 排序方式") 排序方式:ASC升序 DESC降序,默认升序
7,@Keep
标注实体,标注后不会重新为该实体集成代码
8,@Unique
唯一约束,也可以在index属性了添加,不要两者同时添加,会导致性能变差
9,@Generated
标识改方法由greenDao自己生成,不是用户代码,示例代码中删除了大部分该注解下的代码
10,@Convert
如果成员变量是自定义实体,那么需要标注该属性
相关属性:
@converter
用于转换的类
@columnType,数据库中实际存储的类型
写法:
@Convert(converter =BookConverter.class,columnType = String.class)
其中BookConverter需要实现PropertyConverter<T,D>
@Entity(indexes = {@Index(value = "userName ASC",unique = true)})public class User { @Id private String phone; @Unique private String id; private String userName; @NotNull private String passWord; private String bookId; @ToOne(joinProperty = "bookId" ) private Book hisBook; @ToMany(referencedJoinProperty = "phone") private List<Wife> mWife;}
@Entitypublic class Book { @Id private String bookId; private String name; @Generated(hash = 105794982) public Book(String name, String bookId) { this.name = name; this.bookId = bookId; } @Generated(hash = 1839243756) public Book() { }}
@Entitypublic class Wife { private String wifePhone; private String phone; @Id private String sheName;}
阅读全文
0 0
- GreenDao3.0 学习笔记——导入以及注解
- Android笔记之greenDao3.0学习总结
- GreenDao3-注解
- GreenDao3.0学习(一)
- GreenDao3.0学习(二)
- GreenDao3.0学习(三)
- Android GreenDao3.0入门学习
- GreenDao3 api、注解说明
- Java注解学习笔记——自定义注解
- GreenDao3.0新特性解析(配置、注解、加密)
- GreenDao3.0新特性解析(配置、注解、加密)
- GreenDao3.0新特性解析(配置、注解、加密)
- GreenDao3.0新特性解析(配置、注解、加密)
- ORM框架之GreenDao3.0集成与注解(一)
- Java学习笔记——注解
- Kotlin学习笔记——注解
- 学习笔记06—注解(Annotation)
- Android数据存储之ORM解决方案——GreenDao3.0
- TypeScript 枚举使用整理
- springmvc前后端数据交互总结
- 不关闭防火墙 也能ping通机器
- update 批量修改,oracle多表关联修改
- Codeforces Round #416 (Div.2)
- GreenDao3.0 学习笔记——导入以及注解
- Ubuntu 16.04 下使用 MySQL 5.7 + PHP 7 + Apache 部署 Nextcloud
- 欢迎使用CSDN-markdown编辑器
- 《嵌入式Linux应用开发完全手册》---开篇
- HashMap实现原理分析
- NP-complete problems
- android中的长按复制
- linux shell eval命令
- CentOS-CentOS6.8忘记root密码的解决办法(开始初始化也可以用)