GreenDao数据库的使用

本文带大家一步一步搭建GreenDao数据库:

1.添加依赖:

(1)首先在我们的builde.gradle(Module:app)下添加:

       compile 'org.greenrobot:greendao:3.2.0'

         

(2)在builde.gradle(Module:app)的最上面添加:

          apply plugin: 'org.greenrobot.greendao'


(3)builde.gradle(Module:app)中添加:

        greendao{
                  schemaVersion 1
                  targetGenDir 'src/main/java'
        }


具体位置在:


(4)在我们项目的build.gradle(Project)下添加:

         classpath 'org.greenrobot:greendao-gradle-plugin:3.2.0'

   具体位置在:

这样,我们数据库所需要的依赖就添加完成了。

2.创建我们的实体类 Person:

新建class名字为Person(名称随意,本次演示为Person):

@Entity(定义实体)
public class Person {

    @Id(Id,必须为Long类型)
    private Long id;
    private String name;
    private int age;
    @Transient不存储在数据库中)
    private String sex;

    @Generated(hash = 1145075130)     (构造函数或方法,其中 (hash = 1145075130) 这段为后期自动生成,我们不需要去写
    public Person(Long id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }

    @Generated(hash = 1024547259)
    public Person() {
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }
}

3.点击MakeProject:

   
这个时候,系统会自动为我们生成 DaoMaster,DaoSession,PersonDao.

 4.在配置完成后,我们需要进行增删改查的操作,这个时候我们使用单例模式:

(1)首先创建我们的MyApp:


 public class MyApp extends Application {

    private static Context context;
    private static DaoMaster daoMaster;
    private static DaoSession daoSession;

    @Override
    public void onCreate() {
        super.onCreate();
        context = this;
    }

    public static Context getContext() {
        return context;
    }

    public static DaoMaster getDaoMaster() {
        DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(context,"Person.db",null);
        daoMaster = new DaoMaster(helper.getWritableDb());
        return daoMaster;
    }

    public static DaoSession getDaoSession() {
        if (daoSession == null){
            if (daoMaster == null){
                daoMaster = getDaoMaster();
            }
            daoSession = daoMaster.newSession();
        }
        return daoSession;
    }
}

(2)编写我们的DBTool:

public class DBTool {

    private static DBTool dbTool = new DBTool();
    private static PersonDao personDao;

    public static DBTool getInstance(){
        if (dbTool == null){
            synchronized (DBTool.class){
                if (dbTool == null){
                    dbTool = new DBTool();
                }
            }
        }

        personDao = MyApp.getDaoSession().getPersonDao();
        return dbTool;
    }
    //增加单一对象
    public void insertPerson(Person person){
        personDao.insert(person);
    }

    //增加集合
    public void insertList(List<Person>list){
        personDao.insertInTx(list);
    }

    //删除单一的方法
    public void deletePerson(Person person){
        personDao.delete(person);
    }

    //删除所有内容
    public void deleteAll(){
        personDao.deleteAll();
    }

    //根据Id删除
    public void deleteById(Long id){
        personDao.deleteByKey(id);
    }

    //根据某一字段删除
    public void deleteByName(String name){
        DeleteQuery<Person> deleteQuery = personDao.queryBuilder()
                .where(PersonDao.Properties.Name.eq(name))
                .buildDelete();
        deleteQuery.executeDeleteWithoutDetachingEntities();
    }

    //根据具体姓名性别年龄进行删除
    public void deleteBySame(String name,int age){
        DeleteQuery<Person> deleteQuery = personDao.queryBuilder()
                .where(PersonDao.Properties.Name.eq(name)
                ,PersonDao.Properties.Age.eq(age))
                .buildDelete();
        if (deleteQuery!= null){
            deleteQuery.executeDeleteWithoutDetachingEntities();
        }
    }

    //查询所有
    public List<Person>queryAll(){
        //方法1
        List<Person>list = personDao.loadAll();
        //方法2
        List<Person> personlist = personDao.queryBuilder().list();
        return list;
    }

    //查重---根据姓名
    public boolean isSave(String name){
        QueryBuilder<Person>queryBuilder = personDao.queryBuilder()
                .where(PersonDao.Properties.Name.eq(name));
        long size = queryBuilder.buildCount().count();
        return size>0?true:false;
    }

    //查重
    public boolean isSave(Person person){
        QueryBuilder<Person> queryBuilder = personDao.queryBuilder()
                .where(PersonDao.Properties.Name.eq(person.getName()),
                        PersonDao.Properties.Age.eq(person.getAge()));
        Long size = queryBuilder.buildCount().count();
        return size >0 ? true:false;
    }

    //根据姓名修改
    public void changeByName(String name,String newName){
        Person person = personDao.queryBuilder().where(PersonDao.Properties.Name.eq(name)).build().unique();
        if (person!= null){
            person.setName(newName);
        }else {

        }
    }
}

(3)具体的使用:(只提供几种简单的使用,具体复杂的使用,需要自定义实现)

调用DBTool里面的方法

switch (v.getId()){

    //增
    case R.id.btn_insert:
        for (int i = 0; i < 5; i++) {
            Person person = new Person(null,String.valueOf(i),i);
            DBTool.getInstance().insertPerson(person);
        }
        break;

    //删
    case R.id.btn_delete:
        DBTool.getInstance().deleteAll();
        break;

    //改
    case R.id.btn_change:
        DBTool.getInstance().changeByName("2","新名字");
        break;

    //查
    case R.id.btn_query:
        for (  Person person : DBTool.getInstance().queryAll()){
            Log.d("MainActivity", "id:" + person.getId()+"\n"
                    + "name:" + person.getName()+"\n"+ "age:" + person.getAge()
            );
        }
        break;
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值