Android GreenDao3.2配置及使用詳解

1.首先在Androidstudio 項目的build.grad 文件中引入一下文件

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.1'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.0'
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

2.在module的build.gradle文件中添加greenDAO的插件,並引入相關類庫

  
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao'
apply plugin: 'android-apt'
android {
    compileSdkVersion 24
    buildToolsVersion "24.0.2"
    defaultConfig {
        applicationId "com.mvp.observer"
        minSdkVersion 15
        targetSdkVersion 24
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

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

dependencies {
    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:24.2.1'
    testCompile 'junit:junit:4.12'
    compile 'org.greenrobot:greendao:3.2.0'
    compile 'com.android.support:recyclerview-v7:24.2.1'

}

3 .在項目包下創建實體類
  1. @Entity  
  2. public class User {  
  3.     @Id  
  4.     private Long id;  
  5.     @Property(nameInDb = "USERNAME")  
  6.     private String username;  
  7.     @Property(nameInDb = "NICKNAME")  
  8.     private String nickname;  }
  9. @Entity表示這個實體類會在數據庫中生成對應的表,
  10. @Id表示該字段是id,注意該字段的數據類型爲包裝類型Long
  11. @Property則表示該屬性將作爲表的一個字段,其中nameInDb看名字就知道這個屬性在數據庫中對應的數據名稱。
  12. 運行將項目進行編譯,編譯成功之後系統會幫助我們生成相應的構造方法和get/set方法,並且還會在我們的包下生成DaoMaster和DaoSession。那麼這裏常用的註解除了這幾個之外,還有一個較常用的就是@Transient,該註解表示這個屬性將不會作爲數據表中的一個字段。就是這麼簡單。另外還有一些比如@NotNull表示該字段不可以爲空,@Unique表示該字段唯一。這裏的註解還是挺多的,小夥伴們有興趣可以自行研究

創建dbmanager類初始化數據庫

DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(getApplicationContext(), "lenve.db"null);          DaoMaster daoMaster = new DaoMaster(devOpenHelper.getWritableDb());          DaoSession daoSession = daoMaster.newSession();


獲取Dao

      userDao = daoSession.getUserDao();  

    在dbmanager中實現增刪該查 ,添加數據 
  1. User user = new User(null"zhangsan" + random.nextInt(9999),"張三");  
  2.         userDao.insert(user);
  3. 其他大家查看Api實現即可
項目運行結果圖


    項目下載地址  http://download.csdn.net/detail/ldqsxsl/9652535

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章