我相信,在平时的开发过程中,大家一定会或多或少地接触到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文件,添加下面的内容:

至此 配置就完成了,下来就开始生成数据库并使用。

GreenDAO 3.0之前的配置方式可以这里查看。

二、生成数据库操作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和使用方法的更多相关文章

  1. Android Studio配置Git及Git文件状态说明

    Android Studio配置Git还是比较简单的,麻烦的是可能中间出现各种问题.如果你想了解或感兴趣,请往下看. 首先你得下载Git客户端,网址:http://git-scm.com/downlo ...

  2. Android studio 配置JNI环境

    Android studio配置jni开发环境,主要配置是两个build文件,以及新建一个jni文件,放c代码. 代码如下1: apply plugin: 'com.android.model.app ...

  3. 【Flutter 1-2】在 Windows 10下安装Flutter+Dart+Android Studio 配置Flutter开发环境

    在 Windows 10下安装Flutter+Dart+Android Studio 配置Flutter开发环境 文章首发地址 配置环境变量 由于部分网站被墙的原因,我们需要先配置Flutter国内镜 ...

  4. Win10下Android studio配置

    Win10下Android studio配置 一.安装Android Studio的准备工作 1.下载好JDK,去官网上找一个下载下来 2.安装JDK.并配置环境变量.安装过程:本人将使用的是jdk- ...

  5. Android studio配置Git

    Android studio配置Git 1.下载window 版git并安装:下载地址 2.Android Studio设置git插件:File->Setting->Version Con ...

  6. Android Studio 配置SVN实现代码管理

    Refference From:http://iaiai.iteye.com/blog/2267346 一.Android Studio配置SVN Android Studio关联配置SVN很简单,在 ...

  7. Android studio 配置file encoding 无效,中文乱码解决办法

    通过配置Android studio 配置file encoding 无效,中文乱码,问题出现在java编译的时候jack采用了默认编码(中文windows默认的GBK编码)而乱码,所以不管更改bui ...

  8. Android Studio配置使用git

    一.准备 如果没有安装git,那么先要到到Git官网下载git,然后按照提示一步一步安装即可,这个没有什么难度,不过要记得安装的目录. 二.Android Studio配置git File->S ...

  9. android studio配置android开发环境

    1.下载安装android-studio-bundle 地址:https://developer.android.com/sdk/index.html 注意:指定android sdk和android ...

随机推荐

  1. wp版笔记本应用源码

    今天在那个WP教程网看到了一个不错的项目,简单的记事本,主要是用到的独立存储文件的操作,TimePicker和DatePicker的是用,数据绑定,界面的参考的chanraycode的,主要是锻炼自己 ...

  2. pc页面滚动的时候,背景图不动只是页面滚动

    代码如下,直接拷贝出去就能看效果: 用到的方法 background-attachment 属性设置背景图像是否固定或者随着页面的其余部分滚动. <!DOCTYPE html> <h ...

  3. spring cloud(二) zuul

    spring cloud 网关 zuul 搭建过程 1. 新建boot工程 pom引入依赖 <dependency> <groupId>org.springframework. ...

  4. tomcat 配置 https 几点注意

    1.修改server.xml时候把注释的改改就好,不要添加,免得杂乱. 2.安装openssl openssl-devel autoconf libtool apr tomcat-native 才行. ...

  5. Mybatis批量插入的代码实现

    简单的学习总结一下,希望能帮到需要的同学! 1.mapper.xml文件sql语句如下: <insert id="insertBatch" parameterType=&qu ...

  6. jenkins 新增节点的3种方式

    1.通过ssh建立节点(在节点机子上要安装好jdk) (1)通过用户+密码建立ssh连接 (2)通过用户+密钥建立连接 2.通过jnlp,javaweb的方式连接 (1)创建好节点 (2)在节点的机子 ...

  7. Linux菜鸟成长日记 ( Linux 下的 ftp 文件传输协议 )

    https://blog.csdn.net/buster_zr/article/details/80244542 FTP FTP 是 File Transfer Protocol (文件传输协议)的英 ...

  8. 2019-03-29 Vagrant Docker Toolbox 下载安装

    1.无脑安装Vagrant Vagrant是一个基于Ruby的工具,用于创建和部署虚拟化开发环境.它 使用Oracle的开源VirtualBox虚拟化系统,使用 Chef创建自动化虚拟环境. http ...

  9. java spring中对properties属性文件加密及其解密

    http://blog.csdn.net/yaerfeng/article/details/26561791

  10. Hadoop集群(第11期)_常用MySQL数据库命令

    1.系统管理 1.1 连接MySQL 格式: mysql -h主机地址 -u用户名 -p用户密码 举例: 例1:连接到本机上的MySQL. 首先在打开DOS窗口,然后进入目录 mysqlbin,再键入 ...