Android Studio配置GreenDAO 3.2.0和使用方法
我相信,在平时的开发过程中,大家一定会或多或少地接触到SQLite。然而在使用它时,我们往往需要做许多额外的工作,像编写SQL语句与解析查询结果等。所以,适用于Android ORM框架也就孕育而生了,现在市面上主流的框架有OrmLite、SugarORM、Active Android、Realm与GreenDAO。今天主要来讲一下GreenDAO 3.0G后的版本是怎么在Android Studio上配置的。
简单的讲,GreenDAO是一个将对象映射到SQLite数据库中的轻量且快速的ORM解决方案。(greenDAO is a light & fast ORM solution that maps objects to SQLite databases.) 。

一、配置方法
1.直接开始配置,首先找到这个Library,如下图:
2. 找到相应Module的build.gradle文件,添加的下面的内容:
说明:第三步配置的是生成的数据库操作模板代码的路径。
3.找到Project的build.gradle文件,添加下面的内容:
至此 配置就完成了,下来就开始生成数据库并使用。
二、生成数据库操作DAO代码
1.在项目中新建一个表字段的实体类,不需要自己写get和set方法,在生成表的时候会自动生成。不要忘了在类名上标记@Entity注解如图:
2.选择build ——Make Project 一切顺利的话则会在包名下生成数据库的操作类,如下图:
三、使用方法
数据库的操作包括增删改改查,方法如下:
package com.jackie.greendao; import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView; import java.util.List; public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private EditText mName, mAge;
private Button mAdd;
private ListView mListView; private DaoMaster.DevOpenHelper mDevOpenHelper;
private DaoMaster mDaoMaster;
private DaoSession mDaoSession;
private PersonDao mPersonDao; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initView();
initEvent(); openDb();
} private void initView() {
mName = (EditText) findViewById(R.id.name);
mAge = (EditText) findViewById(R.id.age);
mAdd = (Button) findViewById(R.id.add);
mListView = (ListView) findViewById(R.id.list_view);
} private void initEvent() {
mAdd.setOnClickListener(this);
} private void openDb() {
mDevOpenHelper = new DaoMaster.DevOpenHelper(this, "person.db", null);
mDaoMaster = new DaoMaster(mDevOpenHelper.getWritableDb());
mDaoSession = mDaoMaster.newSession();
mPersonDao = mDaoSession.getPersonDao();
} //插入
public void insert() {
Person person = new Person(Long.valueOf(), mName.getText().toString(),
Integer.parseInt(mAge.getText().toString()));
mPersonDao.insert(person); mName.setText("");
mAge.setText("");
} public void delete(Person person) {
mPersonDao.delete(person);
} //更新
public void update(Person person) {
mPersonDao.insertOrReplace(person);
} //查询
public void query() {
List<Person> persons = mPersonDao.queryBuilder().list();
} @Override
public void onClick(View view) {
switch (view.getId()) {
case R.id.add:
insert();
break;
}
}
}
四、查询功能
GreeDAO提供了各种各种的查询API,参见http://greenrobot.org/greendao/documentation/queries/
如果需要在控制台查看GreenDao是怎么拼装SQL语句的,在OnCreate()方法中打开下面的开关:
五、条件查询
//查询所有数据
public void queryAll() {
List<Person> persons = mPersonDao.queryBuilder().list();
} //eq: equal 精确查询 名字等于jackie
public void queryEq() {
Person person = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.eq("jackie")).unique();
} //notEq: not equal 精确查询 名字不等于jackie
public void queryNotEq() {
Person person = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.notEq("jackie")).unique();
} //like 模糊查询 名字以jackie开头
public void queryLike() {
Person person = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.like("jackie")).unique();
//通配符
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.like("jackie%")).list();
} //between 区间查询 年龄在20到30之间
public void queryBetween() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Age.between(, )).list();
} //gt: greater than 半开区间查询,年龄大于18
public void queryGt() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Age.gt()).list();
} //ge: greater equal 半封闭区间查询,年龄大于或者等于18
public void queryGe() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Age.ge()).list();
} //lt: less than 半开区间查询,年龄小于18
public void queryLt() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Age.lt()).list();
} //le: less equal 半封闭区间查询,年龄小于或者等于18
public void queryLe() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Age.le()).list();
} //名字以jackie开头,年龄升序排序
public void queryLikeAsc() {
//通配符
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.like("jackie%")).orderAsc(PersonDao.Properties.Age).list();
} //名字以jackie开头,年龄降序排序
public void queryLikeDesc() {
List<Person> persons = mPersonDao.queryBuilder().where(PersonDao.Properties.Name.like("jackie%")).orderDesc(PersonDao.Properties.Age).list();
}
当上述查询满足不了业务逻辑时,可以自定义查询语句:
六、多线程查询
首先来看错误的方法:
错误截图:
从上面可以看出,只能在创建Query对象的线程中调用查询方法!
解决方法:
七、1对1查询
Android Studio配置GreenDAO 3.2.0和使用方法的更多相关文章
- Android Studio配置Git及Git文件状态说明
Android Studio配置Git还是比较简单的,麻烦的是可能中间出现各种问题.如果你想了解或感兴趣,请往下看. 首先你得下载Git客户端,网址:http://git-scm.com/downlo ...
- Android studio 配置JNI环境
Android studio配置jni开发环境,主要配置是两个build文件,以及新建一个jni文件,放c代码. 代码如下1: apply plugin: 'com.android.model.app ...
- 【Flutter 1-2】在 Windows 10下安装Flutter+Dart+Android Studio 配置Flutter开发环境
在 Windows 10下安装Flutter+Dart+Android Studio 配置Flutter开发环境 文章首发地址 配置环境变量 由于部分网站被墙的原因,我们需要先配置Flutter国内镜 ...
- Win10下Android studio配置
Win10下Android studio配置 一.安装Android Studio的准备工作 1.下载好JDK,去官网上找一个下载下来 2.安装JDK.并配置环境变量.安装过程:本人将使用的是jdk- ...
- Android studio配置Git
Android studio配置Git 1.下载window 版git并安装:下载地址 2.Android Studio设置git插件:File->Setting->Version Con ...
- Android Studio 配置SVN实现代码管理
Refference From:http://iaiai.iteye.com/blog/2267346 一.Android Studio配置SVN Android Studio关联配置SVN很简单,在 ...
- Android studio 配置file encoding 无效,中文乱码解决办法
通过配置Android studio 配置file encoding 无效,中文乱码,问题出现在java编译的时候jack采用了默认编码(中文windows默认的GBK编码)而乱码,所以不管更改bui ...
- Android Studio配置使用git
一.准备 如果没有安装git,那么先要到到Git官网下载git,然后按照提示一步一步安装即可,这个没有什么难度,不过要记得安装的目录. 二.Android Studio配置git File->S ...
- android studio配置android开发环境
1.下载安装android-studio-bundle 地址:https://developer.android.com/sdk/index.html 注意:指定android sdk和android ...
随机推荐
- 【技术累积】【点】【java】【2】聊一聊似曾相识的switch语句
闲聊 有些东西并不能像爱因斯坦老先生说的那样,书上查的到就不用去记住... 开始 java使用了C的所有流程控制语句: java中同样有switch语句: 大多数情况下,switch都可以用if替换: ...
- php常用方法一
1.用户名用***替换 /** * 用户名中间用***替换 * @param string $str 需要替换的字符串 * @param int $len 需要替换的位数 * @param strin ...
- 01-初学总结之《谭浩强C程序设计》
注:个人针对于课本的易错点进行了相关的整理.整理的不专业,多多见谅. C语言中的易出错的点 这个笔记综合了 0. 常量&变量 常量 整型常量 -345,1000,0 实型常量 1) 十进制 ...
- jQuery访问json文件(一个例子)
保存网址 打开时 点开一个类型 当点开一个类型,其他类型隐藏 回到所有类型 没有错,左下角有个这是什么样子的图标 做到了什么: 1.从json文件中取得网址,并根据访问次数排列,放到前面: 2.就是1 ...
- C# 响应一个html页面
System.Text.StringBuilder sb = new System.Text.StringBuilder(); sb.Append("<html><head ...
- UWP 利用DataGrid控件创建表格
通过 Nuget 搜索 Microsoft.Toolkit.Uwp.UI.Controls.DataGrid 安装库,在XAML文件中添加引用库 xmlns:controls="using: ...
- Javase 集合1
package Swxx; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; pu ...
- 洛谷P1567 统计天数
题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...
- [poj 3666] Making the Grade (离散化 线性dp)
今天的第一题(/ω\)! Description A straight dirt road connects two fields on FJ's farm, but it changes eleva ...
- PHP 中 call_user_func 的使用
call_user_func函数类似于一种特别的调用函数的方法,使用方法如下 第一种情况: function set_max($a,$b) { if($a>$b) echo $a; else e ...