GreenDao初识

依赖:
implementation 'org.greenrobot:greendao:3.2.2'
    implementation 'org.greenrobot:greendao-generator:3.2.2'
在Module的build.gradle中配置:
apply plugin: 'org.greenrobot.greendao'
android {
    ......省略
    greendao {
        schemaVersion 1
        daoPackage 'com.example.Test.model.greendao'
        targetGenDir 'src/main/java'
    }
}
在projet的build.gradle中配置:
dependencies {
        .......
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
    }

greenDao的配置:

schemaVersion---->指定数据库schema版本号,迁移等操作会用到

daoPackage-------->通过gradle插件生成的数据库相关文件(设置DaoMaster、DaoSession、Dao包名,也就是要放置这些类的包的全路径。),这里我设置的文件路径是com.example.Test.model.greendao

targetGenDir-------->这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目

在项目里面添加实体类如下:
@Entity
public class User {
    @Id
    private Long id;
    private String name;
}

然后点击 android studio 的 build-->make project

操作数据库:
// 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。
        // 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。
        // 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。
        // 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。
        DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(context,"db",null);//数据库名
        SQLiteDatabase database = devOpenHelper.getWritableDatabase();
        // 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。
        DaoMaster daoMaster = new DaoMaster(database);
        DaoSession daoSession = daoMaster.newSession();
        UserDao userDao = daoSession.getUserDao();

db是数据库的名字,自己随便写就行。 

通过GreenDao生成的代码,我们可以获取到实体类的实例,也就是数据库表的实例,这样我们才能操作数据库

1、增加

User user1 = new User(null,"zhangsan");
userDao.insert(user1);

2、删除

User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("zhangsan")).build().unique();  
if(findUser != null){  
    userDao.deleteByKey(findUser.getId());  
}  

3、修改

User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("zhangsan")).build().unique();  
if(findUser != null) {  
    findUser.setName("lisi");  
    userDao.update(findUser);  
    Toast.makeText(MyApplication.getContext(), "修改成功", Toast.LENGTH_SHORT).show();  
} else {  
    Toast.makeText(MyApplication.getContext(), "用户不存在", Toast.LENGTH_SHORT).show();  
}  

把zhangsan改成lisi 

4、查询

List<User> userList = userDao.queryBuilder()  
       .where(UserDao.Properties.Id.notEq(1)) 
       .limit(5)  
       .build().list(); 

查询语句是数据库操作最多的,语句也比较复杂,具体的语句请去看官网 

猜你喜欢

转载自blog.csdn.net/qq_41673194/article/details/80319189
今日推荐