AndroidAndroid知识Android开发

GreenDao 3.0使用

2017-03-21  本文已影响0人  辩护人

GreenDao介绍

greenDAO是一个对象关系映射(ORM)的框架,能够提供一个接口通过操作对象的方式去操作关系型数据库,它能够让你操作数据库时更简单、更方便。如下图所示:


官网地址:http://greenrobot.org/greendao/
github:https://github.com/greenrobot/greenDAO

GreenDao 优点:

GreenDao环境配置

在 project 的 build.gradle

buildscript {
    repositories {
        jcenter()
        mavenCentral()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

在 app 的 build.gradle

配置GreenDao

greendao{
    schemaVersion=1
    daoPackage 'com.android.example.demo_greendao.dao'
    targetGenDir 'src/main/java'
}
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao'

android {
    compileSdkVersion 23
    buildToolsVersion "25.0.0"
    defaultConfig {
        applicationId "com.android.example.demo_greendao"
        minSdkVersion 15
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:23.4.0'
    testCompile 'junit:junit:4.12'
    compile 'org.greenrobot:greendao:3.2.0'
}

greendao{
    schemaVersion=1
    daoPackage 'com.android.example.demo_greendao.dao'
    targetGenDir 'src/main/java'
}

新建实体类

切记:要将id的类型写为Long,不是小写的long,否则 id 不能自增长。

@Entity
public class PersonInfo {

    @Id
    private Long id;
    private String name;
    private int age;
    private String sex;
}

实体@Entity注解

基础属性注解

索引注解

关系注解

点击一个这个绿色的小锤子

Make Project.png

然后就会自动生成很多东西

生产相关Dao类.png PersonInfo生产后添加.png

新建一个数据库帮助类

使用单例模式

public class GreenDaoManager {

    private DaoMaster.DevOpenHelper helper;
    private DaoMaster daoMaster;
    private DaoSession daoSession;
    private static GreenDaoManager greenDaoManager;

    private GreenDaoManager(Context context) {
        helper = new DaoMaster.DevOpenHelper(context.getApplicationContext(), "GreenDao_DB");
        daoMaster = new DaoMaster(helper.getWritableDb());
        daoSession = daoMaster.newSession();
    }

    public static GreenDaoManager getInstance(Context context) {
        if (greenDaoManager == null){
            synchronized (GreenDaoManager.class){
                if (greenDaoManager == null) {
                    greenDaoManager = new GreenDaoManager(context);
                }
            }
        }
        return greenDaoManager;
    }

    public DaoMaster.DevOpenHelper getDevOpenHelper() {
        return helper;
    }

    public DaoMaster getDaoMaster() {
        return daoMaster;
    }

    public DaoSession getDaoSession() {
        return daoSession;
    }

    public void closeDB() {
        if (helper != null) {
            helper.close();
        }
    }

}

增删改查

PersonInfoDao dao = GreenDaoManager.getInstance(this).getDaoSession().getPersonInfoDao();
PersonInfo infoOne = new PersonInfo("留言",22,"男");
dao.insert(infoOne);

List<PersonInfo> personsList = dao.queryBuilder().build().list();
List<PersonInfo> usersListWhere = dao.queryBuilder().where(PersonInfoDao.Properties.Name.eq("留言")).build().list();

List<PersonInfo> usersListOrder = dao.queryBuilder().where(PersonInfoDao.Properties.Name.eq("留言")).orderAsc(PersonInfoDao.Properties.Age).build().list();

List<PersonInfo> usersListModify = dao.queryBuilder().where(PersonInfoDao.Properties.Name.eq("留言")).build().list();
for (PersonInfo item:usersListModify) {
        item.setName("更新");
        dao.update(item);
 }

删除

List<PersonInfo> usersListDelete = dao.queryBuilder().where(PersonInfoDao.Properties.Name.eq("留言")).build().list();
for (PersonInfo item:usersListDelete) {
       dao.delete(item);
}
dao.deleteAll();

混淆

官方放的位置好隐蔽 官方地址

### greenDAO 3
-keepclassmembers class * extends org.greenrobot.greendao.AbstractDao {
public static java.lang.String TABLENAME;
}
-keep class **$Properties
上一篇 下一篇

猜你喜欢

热点阅读