1. 程式人生 > >greenDao學習了解

greenDao學習了解

時間 屬於 sqlite and pro dbn 優點 base div

參考地址:

https://www.jianshu.com/p/853401a7d02b

https://www.cnblogs.com/zhangqie/p/7250459.html

第一步 先在 項目的Project 的 buil.gradle 裏 在buildscript- repositories添加配置mavenCentral(),

在dependencies 裏添加
classpath‘org.greenrobot:greendao-gradle-plugin:3.1.0‘

第二步 在自己想要用的
GreenDao Module 裏的 dependencies 裏添加

compile‘org.greenrobot:greendao:3.1.0‘

compile‘org.greenrobot:greendao-generator:3.1.0‘

android 裏 添加

greendao{

schemaVersion1

daoPackage‘com.afa.tourism.greendao.gen‘

targetGenDir‘src/main/java‘

}

schemaVersion: 數據庫schema版本,也可以理解為數據庫版本號
daoPackage:設置DaoMaster、DaoSession、Dao包名
targetGenDir:設置DaoMaster、DaoSession、Dao目錄
targetGenDirTest

:設置生成單元測試目錄
generateTests:設置自動生成單元測試用例

頭部 添加

applyplugin:‘org.greenrobot.greendao‘


第三步 創建新的實體類

在實體類 上方 寫 上 @Entity 即可!然後導包而且不需要寫set get 方法。 他自動幫我們生成.. 是不是很牛逼哦?

/** * Created by AFa on 2016/8/23. *

/@Entity

public class User {

@Id(autoincrement = true)

private Long id;

private String name;

private String age;

private String sex;

private String salary;

}


GreenDao 優點:

1.性能高,號稱Android最快的關系型數據庫
2.內存占用小
3.庫文件比較小,小於100K,編譯時間低,而且可以避免65K方法限制
4.支持數據庫加密 greendao支持SQLCipher進行數據庫加密 有關SQLCipher可以參考這篇博客Android數據存儲之Sqlite采用SQLCipher數據庫加密實戰
5.簡潔易用的API


-----------------------------

首先先添加相關配置文件,依賴庫

compile ‘org.greenrobot:greendao:3.+‘

並在庫文件頂部添加:

apply plugin: ‘org.greenrobot.greendao‘

庫文件下定義路徑

greendao {

schemaVersion 1//指定數據庫版本號,更新操作會用到;

daoPackage ‘com.zhangqie.greendao.gen‘//自動生成的dao的包名,包名默認是entity所在的包;

targetGenDir ‘src/main/java‘//生成數據庫文件的目錄

}

在build.gradle文件中添加配置

buildscript {

repositories {

jcenter()

}

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

}

}

通過以上操作就完成我們的基本配置了;

創建一個類User

@Entity

public class User {

@Id(autoincrement = true)

private Long id;//主鍵 自增長

@NotNull //不許為空

private String name;

private String age;

private String content;

}

 package fateat.xinkong.com.greendaotest;

import android.app.Application;
import android.database.sqlite.SQLiteDatabase;

import fateat.xinkong.com.greendaotest.greendao.gen.DaoMaster;
import fateat.xinkong.com.greendaotest.greendao.gen.DaoSession;
//import fateat.xinkong.com.greendaotest.util.dao.Helper;

public class MyApplication extends Application {

private DaoMaster.DevOpenHelper mHelper;
private SQLiteDatabase db;
private DaoMaster mDaoMaster;
private DaoSession mDaoSession;


public static MyApplication instance;

public static MyApplication getInstances(){
return instance;
}

@Override
public void onCreate() {
super.onCreate();
instance = this;
setDatabase();
}

private void setDatabase(){
mHelper =new DaoMaster.DevOpenHelper(this, "notes-db", null);//new Helper(this);//
db = mHelper.getWritableDatabase();
// 註意:該數據庫連接屬於 DaoMaster,所以多個 Session 指的是相同的數據庫連接。
mDaoMaster = new DaoMaster(db);
mDaoSession = mDaoMaster.newSession();
}

public DaoSession getDaoSession() {
return mDaoSession;
}
public SQLiteDatabase getDb() {
return db;
}
}
 

版本升級更新

比如需要在實體類加一個字段 或者 改變字段屬性等 就需要版本更新來保存以前的數據了;

我的案例中是加了一個 times的字段;

1:需要一個MigrationHelper.java一位大神寫的 直接拿來用即可

地址:https://stackoverflow.com/questions/13373170/greendao-schema-update-and-data-migration/30334668#30334668

2:接下來就是我們 GreenApplication 類裏的 Helper類了

public class Helper extends DaoMaster.OpenHelper{

private static DaoMaster daoMaster;

private static DaoSession daoSession;

public static final String DBNAME = "greendao.db";

public Helper(Context context){

super(context,DBNAME,null);

}

@Override

public void onUpgrade(Database db, int oldVersion, int newVersion) {

super.onUpgrade(db, oldVersion, newVersion);

Log.i("version", oldVersion + "---先前和更新之後的版本---" + newVersion);

if (oldVersion < newVersion) {

Log.i("version", oldVersion + "---先前和更新之後的版本---" + newVersion);

MigrationHelper.getInstance().migrate(db, UserDao.class);

//更改過的實體類(新增的不用加) 更新UserDao文件 可以添加多個 XXDao.class 文件

// MigrationHelper.getInstance().migrate(db, UserDao.class,XXDao.class);

}

}

/**

* 取得DaoMaster

*

* @param context

* @return

*/

public static DaoMaster getDaoMaster(Context context) {

if (daoMaster == null) {

DaoMaster.OpenHelper helper = new DaoMaster.DevOpenHelper(context,

DBNAME, null);

daoMaster = new DaoMaster(helper.getWritableDatabase());

}

return daoMaster;

}

/**

* 取得DaoSession

*

* @param context

* @return

*/

public static DaoSession getDaoSession(Context context) {

if (daoSession == null) {

if (daoMaster == null) {

daoMaster = getDaoMaster(context);

}

daoSession = daoMaster.newSession();

}

return daoSession;

}

}

完成相關操作之後;還要改數據庫版本

greendao {

schemaVersion 2//改版本號為2

daoPackage ‘com.zhangqie.greendao.gen‘;

targetGenDir ‘src/main/java‘

}

編譯運行,可以去實體類和UserDao查看 增加的字段相關信息自動生成完成;

當然先前的版本1 中的數據也是存在的,只不過 新添加的字段 的值全部為空而已;


greenDao學習了解