利用greendao操作数据库时,都是以对象或者对象的list来进行增删改查的操作,操作的结果都是用一个list来接收的!!!

1.增加一条记录

Stu stu01=new Stu();
stu01.setStuID(11);
stu01.setStuName("张三");
stu01.setFlag(true);
stuDao().insert(stu01);

2.增加多条记录

List<Stu> list = new ArrayList<>();
Stu stu01=new Stu();
stu01.setStuID(11);
stu01.setStuName("张三");
stu01.setFlag(true);
list.add(stu01); Stu stu02=new Stu();
stu02.setStuID(2);
stu02.setStuName("王五");
stu02.setFlag(true);
list.add(stu02); Stu stu03=new Stu();
stu03.setStuID(Long.valueOf(5));
stu03.setStuName("李四");
stu03.setFlag(true);
list.add(stu03);
stuDao().insertInTx(list);

3.删除一条记录

(1)按对象删除

     stuDao().delete(stu01);

(2)按主键删除(表中需建一个long类型的主键)

      stuDao().deleteByKey(Long.valueOf(5));

4.删除多条记录(表中需建一个long类型的主键)

List<Stu> list = new ArrayList<>();
Stu stu01=new Stu();
stu01.setId(Long.valueOf(1));
stu01.setStuID(11);
stu01.setStuName("张三");
stu01.setFlag(true);
list.add(stu01);
Stu stu02=new Stu();
stu02.setId(Long.valueOf(2));
stu02.setStuID(2);
stu02.setStuName("王五");
stu02.setFlag(true);
list.add(stu02);
stuDao().deleteInTx(list);

5.全部删除

stuDao().deleteAll();

6.修改一条记录(表中需建一个long类型的主键)

Stu stu=stu01;
stu.setStuName("张小磊");
stuDao().update(stu);

7.修改多条记录

List<Stu> list = new ArrayList<>();
Stu stu=stu01;
stu.setStuName("张小磊");
list.add(stu); stu=stu02;
stu.setStuName("招儿");
list.add(stu);
stuDao().updateInTx(list);

8.查询一条记录

根据一个字段查询另一个字段

public static String queryNameByID(long ID) {
List<Stu> stus = stuDao().queryRaw("where ID=?", String.valueOf(ID));
Stu stu = stus.get(0);
String name = stu.getName();
return name;
}

9.查询多条记录

(1)查询出当一个字段为多个值的情况下所有的记录

public static List<Stu> queryStus() {
List<Stu> stus = new ArrayList<>();
QueryBuilder queryBuilder = stuDao().queryBuilder();
queryBuilder.whereOr(StuDao.Properties.StuID.eq(2), StuDao.Properties.StuID.eq(3));
stus = queryBuilder.list();
return stus;
}

(2)对查询的记录进行升序(降序)排序

public static List<Stu> queryStus() {
List<Stu> stus = new ArrayList<>();
QueryBuilder queryBuilder = stuDao().queryBuilder();
queryBuilder.where(StuDao.Properties.Flag.eq(true)).orderAsc(StuDao.Properties.StuID);
stus = queryBuilder.list();
return stus;
}

(3)嵌套查询

public static List<Stu> queryStu() {
List<Stu> stus = new ArrayList<>();
QueryBuilder queryBuilder = stuDao().queryBuilder(); queryBuilder.where(StuDao.Properties.Flag.eq(true),
queryBuilder.or(StuDao.Properties.StuName.eq("张小磊"),
StuDao.Properties.StuName.eq("王五"))); stus = queryBuilder.list();
return stus;
}

greendao对SQLite数据库的增删改查操作的更多相关文章

  1. PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码

    PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...

  2. python web.py操作mysql数据库,实现对数据库的增删改查操作

    使用web.py框架,实现对mysql数据库的增删改查操作: 该示例代码中连接的是本地数据库testdb,user表,表结构比较简单,只有两个字段:mobile和passwd,类型均为字符型 实际应用 ...

  3. TP5.1:数据库的增删改查操作(基于面向对象操作)

    我们现实中对数据库的增删改查操作,都是使用模型类进行操作的(表名::),也就是面向对象操作,只有底层的代码用的是数据库操作(Db::table('表名')) 下面我将贴出模型类进行的增删改查操作,通过 ...

  4. 通过jdbc连接MySql数据库的增删改查操作

    一.获取数据库连接 要对MySql数据库内的数据进行增删改查等操作,首先要获取数据库连接 JDBC:Java中连接数据库方式 具体操作如下: 获取数据库连接的步骤: 1.先定义好四个参数 String ...

  5. android 对sqlite数据库的增删改查等各种操作

    转载:http://blog.csdn.net/vrix/article/details/6717090 package com.sqlite.main; import java.io.File; i ...

  6. Android中Sqlite数据库进行增删改查

    今天这篇文章写Sqlite数据库,通过一个小案例来完整讲一下数据库常见的CRUD操作. 先对知识点总结: SQLite数据库 轻量级关系型数据库 创建数据库需要使用的api:SQLiteOpenHel ...

  7. TP5.1:数据库的增删改查操作(基于数据库操作)

    1.在app/index/controller文件夹下创建一个文件,名为:Operation 注意:起名一定要避开关键字,例如:mysql,curd等等,如果使用关键字起名,会造成报错! 在Opera ...

  8. Android下利用SQLite数据库实现增删改查

    1: 首先介绍如何利用adb查看数据库 1: adb shell 2: cd /data/data/包名/databases 3:  sqlite3 数据库 4   接下来就可以进行数据库的sql语法 ...

  9. Android对Sqlite数据库的增删改查

    SqLite 数据库 Google 为我们提供了sqlite相关的api SqLiteOpenHelper 这是一个抽象的类 如果想要使用的话,需要其他的类去继承他 SqLiteDatabase 类 ...

随机推荐

  1. JS-改变页面的颜色之变化核心-获取六位的随机数

    前言:从JS-改变页面的颜色(一).JS-改变页面的颜色(二).JS-改变页面的颜色(三)三个简单的小白例,我们可以轻而易举的看到起变化的核心是——十六进制颜色值的获取方式,所以,我们这里总结一下获取 ...

  2. Mutex

    #include "stdafx.h" #include <string> #include <iostream> #include <Windows ...

  3. Asp.net core 通过Models 生成数据库的方法

        其实Getting Started当中有着详细的说明,https://docs.efproject.net/en/latest/platforms/aspnetcore/new-db.html ...

  4. 【SSM 8】spring集成Mybatis通用Mapper

    上篇博客中介绍了关于Mybatis底层封装的思路问题,那么这篇博客,就介绍一下怎么引入通用的mapper插件. 备注:本项目通过maven管理 关键版本说明: spring:4.1.3.RELEASE ...

  5. thinkphp修改及编写标签库,编辑器的使用

    在view目录下创建Index_aaa.html <!DOCTYPE html> <html> <head> <meta charset="UTF- ...

  6. adb常用命令

    adb命令的主要用途  1. 运行android设备的shell(命令行).  2.管理模拟器或android设备的映射端口.  3. 安装和卸载应用程序.  4.计算机和android设备之间的上传 ...

  7. string、Empty和null三者的区别

    string.Empty和null三者的区别 本文转自  http://www.bitscn.com/pdb/dotnet/201003/181883.html 时间:2010-03-01 00:00 ...

  8. java中的那些坑

    最近准备换工作,为了少让人家鄙视,就要狠狠地藐视这些面试题目.找了本电子书,发了有好多坑,都是特别简单,但是很少有人做对的题目.面对这样的题目,我却有一种兴奋的感觉,也许是因为一直做着重复的工作没有新 ...

  9. input[file]标签的accept=”image/*”属性响应很慢的解决办法

    转自:http://blog.csdn.net/lx583274568/article/details/52983693 input[file]标签的accept属性可用于指定上传文件的 MIME类型 ...

  10. 签名 cd

    http://blog.sina.com.cn/s/blog_618199e60101uc7w.html