GreenDao初识

版权声明:本文为博主原创文章,转载请注明出处。 https://blog.csdn.net/qq_41673194/article/details/80319189
依赖:
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

操作数据库:
public class DaoManager {
    private static DaoManager daoManager;
    private static DaoMaster.DevOpenHelper devOpenHelper;
    private static SQLiteDatabase database;
    private static DaoMaster daoMaster;
    private static DaoSession daoSession;
    private static UserDao userDao;

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

    public SQLiteDatabase getDb() {
        return database;
    }
    public DaoSession getDaoSession() {
        return daoSession;
    }
    public UserDao getUserDao(){
        return userDao;
    }
}

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(); 

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

阅读更多
想对作者说点什么?
相关热词

博主推荐

换一批

没有更多推荐了,返回首页