Android 数据库框架GreenDao使用
1.GreenDao3介绍
(1)基本概念
(2)GreenDao3工作原理
(3)GreenDao优点
(4)GreenDao3版本的改进
2.GreenDao3的相关配置概念介绍
(1)配置项目(Project)的build.gradle
(2)配置模组(Module)的build.gradle
3.GreenDao3配置实战
(1)打开现有的Android studio工程
(2)配置项目(Project)的build.gradle
buildscript{
//repositories相当于一个存储jar包的仓库
repositories {
mavenCentral() //到网上的Maven仓库的服务器里下载库文件
}
//dependencies包含所有真正依赖的库文件
dependencies{
//将GreenDao的插件库文件引入项目
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'
}
}
(3)配置模组(Module)的build.gradle
在文件的最后添加
//应用GreenDao插件
apply plugin: 'org.greenrobot.greendao'
greendao{ //设置greendao的相关参数
schemaVersion 3 //设置数据库版本
daoPackage 'com.example.lucky.mygreendaotest.gen' //生成DAO、DAOMaster、DAOSession的包名(这句代码应根据实际project文件位置进行相应修改)
targetGenDir 'src/main/java' //生成DAOs、DAOMaster、DAOSession的目录
}
dependencies{
implementation fileTree(dir: 'libs', include: ['*.jar']) //用于项目编译的库文件及所在目录
implementation 'com.android.support:appcompat-v7:28.0.0'
//导入greendao的相关库文件
implementation 'org.greenrobot:greendao:3.2.0'
implementation 'org.greenrobot:greendao-generator:3.2.0' }
注意:以上代码中有一处要根据实际情况进行修改
daoPackage 'com.example.lucky.mygreendaotest.gen' //生成DAO、DAOMaster、DAOSession的包名(这句代码应根据实际project文件位置进行相应修改)
其中com.example.lucky.mygreendaotest为工程的包名,可用实际工程的manifest.xml文件的包名(package对应内容)替换
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.administrator.test62360safeguard">
(4) 进行项目同步
点击Sync Now
可见如下图
(5)实体类及其注解
<1>介绍
<2>实体类注解及其作用
<3>创建实体类并完成注解
<4>新建实体类后,通过build--->make project 编译工程,会自动生成代码(实体类BlackListCallEntity中有一部分、还有DaoMaster.java、DaoSession.java、BlackListCallEntityDao.java)
注意:主键id的数据类型是Long而不是long
以下是未编译的实体类BlackListCallEntity的代码:
package com.example.administrator.test62360safeguard.Entity; import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Generated; @Entity(
//设置数据库的表名
nameInDb ="black_list_call"
)
public class BlackListCallEntity {
@Id(autoincrement = true)
private Long id; //注意:id的数据类型是Long而不是long
private String phoneNumber;
private String functionType;
}
经过编译后的实体类:
package com.example.administrator.test62360safeguard.Entity; import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Generated; @Entity(
//设置数据库的表名
nameInDb ="black_list_call"
)
public class BlackListCallEntity {
@Id(autoincrement = true)
private Long id; //注意:id的类型是Long而不是long
private String phoneNumber;
private String functionType;
@Generated(hash = 533022796)
public BlackListCallEntity(Long id, String phoneNumber, String functionType) {
this.id = id;
this.phoneNumber = phoneNumber;
this.functionType = functionType;
}
@Generated(hash = 1836403501)
public BlackListCallEntity() {
}
public Long getId() {
return this.id;
}
public void setId(Long id) {
this.id = id;
}
public String getPhoneNumber() {
return this.phoneNumber;
}
public void setPhoneNumber(String phoneNumber) {
this.phoneNumber = phoneNumber;
}
public String getFunctionType() {
return this.functionType;
}
public void setFunctionType(String functionType) {
this.functionType = functionType;
} }
(6)新建2个java类(HMROpenHelper、MyGreenDaoApplication)
<1>HMROpenHelper类的源码
package com.example.lucky.mygreendaotest; import android.content.Context;
import android.database.sqlite.SQLiteDatabase; import com.example.lucky.mygreendaotest.gen.DaoMaster; //数据库创建工具类
public class HMROpenHelper extends DaoMaster.OpenHelper {
//构造函数,参数2 name为数据库名称
public HMROpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
super(context, name, factory);
}
}
<2>MyApplication类的源码
通常我们是不需要指定一个Application的,系统会自动帮我们创建,如果需要创建自己的Application,那也很简单!创建一个类继承Application并在AndroidManifest.xml文件中的application标签中进行注册(只需要给application标签增加name属性,并添加自己的 Application的名字即可)
当Android程序启动时系统会创建一个Application对象,用来存储系统的一些信息。
Android系统自动会为每个程序运行时创建一个Application类的对象且只创建一个,所以Application可以说是单例(singleton)模式的一个类。
package com.example.administrator.test62360safeguard; import android.app.Application;
import android.database.sqlite.SQLiteDatabase; import com.example.administrator.test62360safeguard.GreenDao.DaoMaster;
import com.example.administrator.test62360safeguard.GreenDao.DaoSession;
import com.example.administrator.test62360safeguard.GreenDaoUtils.HMROpenHelper; /**
* 注意:MyApplication类继承Application,需要在AndroidManifest.xml文件中进行相关设置
* android:name=".MyApplication"
* MyApplication类的作用是封装数据库对象
*/
public class MyApplication extends Application {
private SQLiteDatabase db; //SQLiteDatabase数据库对象
private DaoMaster daoMaster; //daoMaster对象
private DaoSession daoSession; //daoSession对象
public static MyApplication instances; //声明本类的实例对象 @Override
public void onCreate() {
super.onCreate();
instances=this; //给实例对象赋值
setDatabase();
} private void setDatabase() {
//创建数据库,参数2是所创建的数据库的名称
HMROpenHelper hmrOpenHelper=new HMROpenHelper(this,"mydb1",null);
db=hmrOpenHelper.getWritableDatabase(); //获取数据库对象
daoMaster=new DaoMaster(db); //获取DaoMaster对象
daoSession=daoMaster.newSession(); } //获取instances 对象
public static MyApplication getInstances(){
return instances;
} //获取daoSession对象
public DaoSession getDaoSession(){
return daoSession;
} public SQLiteDatabase getDb(){
return db;
}
}
(7)编译工程,安装到模拟器后,打开应用时,就会自动创建数据库
模拟器中app内的数据库文件导出方法:
6.GreenDao3添加记录(SQLite 增)
(1)基本原理
7.GreenDao3删除记录(SQLite 删)
8.GreenDao3修改记录(SQLite 改)
参考文献:https://www.jianshu.com/p/793f77feeb89
https://www.cnblogs.com/tonycheng93/p/6295724.html(推荐)
Android 数据库框架GreenDao使用的更多相关文章
- Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite
Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射 ...
- Android 数据库框架GreenDao实战使用
1.添加记录(SQLite 增) 2.删除记录(SQLite 删) 3.修改记录(SQLite 改) 4.查询记录(SQLite 查) <1> DAO查询 <2>QueryBu ...
- Android 数据库框架总结(转)
转自 http://blog.csdn.net/da_caoyuan/article/details/61414626 一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完 ...
- Android 数据库框架总结,总有一个适合你!
一:OrmLite 简述: 优点: 1.轻量级:2.使用简单,易上手:3.封装完善:4.文档全面.缺点:1.基于反射,效率较低(本人还没有觉得效率低):2.缺少中文翻译文档 jar包 地址:http: ...
- Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的, ...
- ORM数据库框架 greenDAO SQLite MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Android 数据库框架OrmLite的使用(一)
在这里记录下最基本的用法,官网上可了解相关的介绍. 1.下载OrmLite jar 在下载android的:ormlite-android-4.48.jar和ormlite-core-4.48.jar ...
- Android 数据库框架ormlite
Android 数据库框架ormlite 使用精要 前言 本篇博客记录一下笔者在实际开发中使用到的一个数据库框架,这个可以让我们快速实现数据库操作,避免频繁手写sql,提高我们的开发效率,减少出错的机 ...
- Android数据库框架-----ORMLite关联表的使用
上一篇已经对ORMLite框架做了简单的介绍:Android数据库框架-----ORMLite 的基本用法~~本篇将介绍项目可能会使用到的一些用法,也为我们的使用ORMLite框架总结出一个较合理的用 ...
随机推荐
- Leetcode:Task Scheduler分析和实现
题目大意:提供k个任务,这些任务没有依赖关系(即可以任意调度).CPU完成一个任务需要耗时一个时间片段,当执行完一个任务后,相同的任务必须在n个时间片段才能得以执行.请问CPU通过调度最快能在多少时间 ...
- AntD02 Table组件的使用
1 前提准备 1.1 创建一个angular项目 1.2 将 Ant Design 整合到 Angular 项目中 1.3 官方文档 点击前往 2 简单使用 <nz-table #rowSele ...
- matplotlib的颜色和控制条
为了方便记忆,收藏备用 一 linestyle '-' solid line style '--' dashed line style '-.' dash-dot line style ':' dot ...
- SP1557 GSS2 - Can you answer these queries II
一开始看不懂题解,看懂了题解之后觉得还是挺妙的. 好多题解里都提到了HH的项链,但是我觉得关系并不大啊…… 先把所有询问离线下来按照右端点排序,按照询问的要求一个一个加入数字,怎么加入数字,我们设计一 ...
- 几种导入osm(openstreetmap)数据的方法
一osm2pgsql+postgresql+postgis osm2pgsql——是由OpenStreetMap开发的一个命令行工具负责将OSM数据导入到基于PostgresSql的Postgis的 ...
- Django----解决跨域
cors(跨域资源共享): 本质设置响应头 定制中间件 cors.py 后在settings.py中间件中配置 from django.utils.deprecation import Middlew ...
- c# 二分查找法(2分钟算法)
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
- 【linux命令】setterm控制终端属性命令(中英文)
[linux命令]setterm控制终端属性命令(中英文) 2018年03月23日 17:13:44 阅读数:489 标签: linux 更多 个人分类: linux 摘自:https://blog. ...
- python 字符串,元组, 列表,字典之间的转换
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- (转)Asp.Net生命周期系列一
原文地址:http://www.cnblogs.com/skm-blog/archive/2013/07/07/3176713.html Asp.Net生命周期对于初级甚至中级程序员来说,一直都是一个 ...