【开发框架】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

相关文章

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

Redis中的Lettuce使用详解

《Redis中的Lettuce使用详解》Lettuce是一个高级的、线程安全的Redis客户端,用于与Redis数据库交互,Lettuce是一个功能强大、使用方便的Redis客户端,适用于各种规模的J... 目录简介特点连接池连接池特点连接池管理连接池优势连接池配置参数监控常用监控工具通过JMX监控通过Pr

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Java使用MethodHandle来替代反射,提高性能问题

《Java使用MethodHandle来替代反射,提高性能问题》:本文主要介绍Java使用MethodHandle来替代反射,提高性能问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录一、认识MethodHandle1、简介2、使用方式3、与反射的区别二、示例1、基本使用2、(重要)

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元