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 .在項目包下創建實體類
- @Entity
- public class User {
- @Id
- private Long id;
- @Property(nameInDb = "USERNAME")
- private String username;
- @Property(nameInDb = "NICKNAME")
- private String nickname; }
- @Entity表示這個實體類會在數據庫中生成對應的表,
- @Id表示該字段是id,注意該字段的數據類型爲包裝類型Long
- @Property則表示該屬性將作爲表的一個字段,其中nameInDb看名字就知道這個屬性在數據庫中對應的數據名稱。
- 運行將項目進行編譯,編譯成功之後系統會幫助我們生成相應的構造方法和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中實現增刪該查 ,添加數據
- User user = new User(null, "zhangsan" + random.nextInt(9999),"張三");
- userDao.insert(user);
- 其他大家查看Api實現即可
項目下載地址 http://download.csdn.net/detail/ldqsxsl/9652535