【开发框架】GreenDao数据库框架的搭建和使用

2024-02-29 04:32

本文主要是介绍【开发框架】GreenDao数据库框架的搭建和使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

阔别好久的Android开发平台,由于公司需要又转战过来进行开发,首先就是我要搭建公司Andorid平台的项目框架,都使用什么快速开发框架进行开发。数据库方面的框架,经过挑选,我选用了GreenDao框架,下面就讲一下该框架的配置和使用方法。注意:我是在AS开发工具下。

GreenDao配置

需要在工程(Project)的build.gradle中添加依赖

buildscript {repositories {jcenter()}dependencies {classpath 'com.android.tools.build:gradle:2.0.0'//GreenDao3依赖classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'}
}

在项目(Module)的build.gradle中添加依赖

apply plugin: 'com.android.application'
apply plugin: 'com.neenbedankt.android-apt'
//使用greendao
apply plugin: 'org.greenrobot.greendao'
android {compileSdkVersion 23buildToolsVersion "25.0.0"defaultConfig {applicationId "com.cdfy.iapp"minSdkVersion 21targetSdkVersion 21versionCode 1versionName "1.0"testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"}
    //greendao配置greendao {//版本号,升级时可配置schemaVersion 1}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'}}
}
dependencies {compile fileTree(dir: 'libs', include: ['*.jar'])androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {exclude group: 'com.android.support', module: 'support-annotations'})compile 'com.android.support:appcompat-v7:23.3.0'compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha8'testCompile 'junit:junit:4.12'apt 'com.jakewharton:butterknife-compiler:8.0.0'compile 'com.jakewharton:butterknife:8.0.0'
    //greendao依赖compile 'org.greenrobot:greendao:3.2.0'
}
以上就算配置成功,迈出了第一步!

GreenDao使用

数据库操作需要:数据库名、表名、字段名,缺一不可。简单来说,这个框架类似标签类的,数据库名就是获得连接时填写的数据库名(稍后说到),表名就是实体的名字,字段就是JAVA实体类中的成员变量。

@Entity
public class User {//不能用int@Id(autoincrement = true)private Long id;//用户名@Uniqueprivate String username;//密码@Uniqueprivate String password;
}

这里需要注意的是,创建完成之后,需要build gradle来完成我们的代码自动生成。

自动生成的代码有 Bean实体的构造方法和get、set方法, DaoMaster、DaoSession、DAOS类。生成方法如下图:

点击红色按钮即可,代码就会自动生成。

Bean对象的注释进行解释

  1. @Entity:告诉GreenDao该对象为实体,只有被@Entity注释的Bean类才能被dao类操作

  2. @Id:对象的Id,使用Long类型作为EntityId,否则会报错。(autoincrement = true)表示主键会自增,如果false就会使用旧值

  3. @Property:可以自定义字段名,注意外键不能使用该属性

  4. @NotNull:属性不能为空

  5. @Transient:使用该注释的属性不会被存入数据库的字段中

  6. @Unique:该属性值必须在数据库中是唯一值

  7. @Generated:编译后自动生成的构造函数、方法等的注释,提示构造函数、方法等不能被修改

创建数据库

GreenDao数据库创建

public class BaseApplication extends Application {private static DaoSession daoSession;@Overridepublic void onCreate() {super.onCreate();setupDatabase();}/*** 配置数据库*/private void setupDatabase() {//创建数据库app.db"DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this, "app.db", null);//获取可写数据库SQLiteDatabase db = helper.getWritableDatabase();//获取数据库对象DaoMaster daoMaster = new DaoMaster(db);//获取Dao对象管理者daoSession = daoMaster.newSession();}public static DaoSession getDaoInstant() {return daoSession;}
}
GreenDao已经将我们的数据库创建缩成几句话,代码会自动将Bean对象创建成表,不再是传统的手写SQL语句。这里的数据库创建只需要在Application中执行一次即可,这里对几个类进行解释

  1. DevOpenHelper:创建SQLite数据库的SQLiteOpenHelper的具体实现

  2. DaoMaster:GreenDao的顶级对象,作为数据库对象、用于创建表和删除表

  3. DaoSession:管理所有的Dao对象,Dao对象中存在着增删改查等API

由于我们已经创建好了DaoSession和Shop的Bean对象,编译后会自动生成我们的UserDao对象,可通过DaoSession获得

UserDao dao = daoSession.getUserDao();

这里的Dao(Data Access Object)是指数据访问接口,即提供了数据库操作一些API接口,可通过dao进行增删改查操作

GreenDao增删改查

先看我写的例子代码,最简单的实现:

@OnClick({R.id.btAdd, R.id.btQuery, R.id.btUpdate, R.id.btDelete})public void onViewClicked(View view) {
 List<User> list=null;
UserDao dao = BaseApplication.getDaoInstant().getUserDao();String username = etUsername.getText().toString();String password = etPassword.getText().toString();switch (view.getId()) {case R.id.btAdd:
  //增加
User user = new User();user.setUsername(username);user.setPassword(password);long i1 = dao.insert(user);Toast.makeText(this, String.valueOf(i1), Toast.LENGTH_SHORT).show();break;case R.id.btQuery:
//查询所有
list = dao.loadAll();StringBuffer strbuff = new StringBuffer();for (int i = 0; i < list.size(); i++) {strbuff.append("ID:").append(list.get(i).getId()).append("用户名:").append(list.get(i).getUsername()).append("密码:").append(list.get(i).getPassword()).append(";");}tvText.setText(strbuff.toString());break;case R.id.btUpdate:
//更新
User users = list.get(Integer.parseInt(etId.getText().toString()));users.setUsername(username);users.setPassword(password);dao.update(users);break;case R.id.btDelete:
 //删除按照ID进行的删除 
dao.deleteByKey(Long.parseLong(etId.getText().toString()));break;}}

API的介绍

  • 增加单个数据

    • getShopDao().insert(shop);

    • getShopDao().insertOrReplace(shop);

  • 增加多个数据

    • getShopDao().insertInTx(shopList);

    • getShopDao().insertOrReplaceInTx(shopList);

  • 查询全部

    • List< Shop> list = getShopDao().loadAll();

    • List< Shop> list = getShopDao().queryBuilder().list();

  • 查询附加单个条件

    • .where()

    • .whereOr()

  • 查询附加多个条件

    • .where(, , ,)

    • .whereOr(, , ,)

  • 查询附加排序

    • .orderDesc()

    • .orderAsc()

  • 查询限制当页个数

    • .limit()

  • 查询总个数

    • .count()

  • 修改单个数据

    • getShopDao().update(shop);

  • 修改多个数据

    • getShopDao().updateInTx(shopList);

  • 删除单个数据

    • getTABUserDao().delete(user);

  • 删除多个数据

    • getUserDao().deleteInTx(userList);

  • 删除数据ByKey

    • getTABUserDao().deleteByKey();

结尾

还有好多的用法,这里只是介绍个简单基础用法,其他的比如多表查询,主外键关联等等自行百度或者官网学习,有时间我也会更新。

这篇关于【开发框架】GreenDao数据库框架的搭建和使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757585

相关文章

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的