關(guān)于GreenDao
greenDao是一個將對象映射到SQLite數(shù)據(jù)庫中的輕量且快速的ORM解決方案曾雕。
關(guān)于greenDAO的概念可以看官網(wǎng)greenDAO
greenDAO 優(yōu)勢
1衅澈、一個精簡的庫
2靖苇、性能最大化
3响蓉、內(nèi)存開銷最小化
4、易于使用的 APIs
5、對 Android 進行高度優(yōu)化
GreenDao 3.0使用
GreenDao 3.0采用注解的方式來定義實體類,通過gradle插件生成相應(yīng)的代碼妹懒。
一,在as中導(dǎo)入相關(guān)的包
compile'org.greenrobot:greendao:3.0.1'
compile'org.greenrobot:greendao-generator:3.0.0'
二双吆、在build.gradle中進行配置:(該處配置屬于工程build眨唬,不能再moudle進行配置)
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.greenrobot:greendao-gradle-plugin:3.0.0'
}
}
三、自定義路徑(moudle配置)
apply plugin: 'org.greenrobot.greendao'
android {
greendao {
schemaVersion 1
daoPackage 'com.example.msi.greeandao'
targetGenDir 'src/main/java'
}
基本注釋屬性
@ID?? 一般會選擇long/Long屬性作為Entity ID(即數(shù)據(jù)庫中的主鍵)autoincrement=true表示主鍵會自增如果false就會使用舊值
@Property?? 可以自定義一個該屬性在數(shù)據(jù)庫中的名稱好乐,默認情況下數(shù)據(jù)庫中該屬性名稱是Bean對象中的 屬性名但是不是以駝峰式而是以大寫與下劃線組合形式來命名的比如:customName將命名為 CUSTOM_NAME;注意:外鍵不能使用該屬性匾竿;
@NotNull?? 確保屬性值不會為null值;
@Transient??? 使用該注釋的屬性不會被存入數(shù)據(jù)庫中;
主鍵限制每個實體類都應(yīng)該有一個long或者LONG型屬性作為主鍵;如果你不想用long或者LONG型作為主鍵蔚万,你可以使用一個唯一索引(使用@Index(unique = true)注釋使普通屬性改變成唯一索引屬性)屬性作為關(guān)鍵屬性岭妖。
greendao中的注解
(一) @Entity 定義實體
@nameInDb 在數(shù)據(jù)庫中的名字,如不寫則為實體中類名
@indexes 索引
@createInDb 是否創(chuàng)建表,默認為true,false時不創(chuàng)建
@schema 指定架構(gòu)名稱為實體
@active 無論是更新生成都刷新
(二) @Id
(三) @NotNull 不為null
(四) @Unique 唯一約束
(五) @ToMany 一對多
(六) @OrderBy 排序
(七) @ToOne 一對一
(八) @Transient 不存儲在數(shù)據(jù)庫中
(九) @generated 由greendao產(chǎn)生的構(gòu)造函數(shù)或方法
==========================================================================
附上Application配置:
public class MyApplication extends Application {
private DaoMaster.DevOpenHelper mHelper;
private SQLiteDatabase db;
private DaoMaster mDaoMaster;
private DaoSession mDaoSession;
public static MyApplication instances;
@Override
public void onCreate() {
super.onCreate();
instances = this;
setDatabase();
}
public static MyApplication getInstances(){
return instances;
}
/**
* 設(shè)置greenDao
*/
private void setDatabase() {
// 通過 DaoMaster 的內(nèi)部類 DevOpenHelper昵慌,你可以得到一個便利的 SQLiteOpenHelper 對象假夺。
// 可能你已經(jīng)注意到了,你并不需要去編寫「CREATE TABLE」這樣的 SQL 語句斋攀,因為 greenDAO 已經(jīng)幫你做了已卷。
// 注意:默認的 DaoMaster.DevOpenHelper 會在數(shù)據(jù)庫升級時,刪除所有的表蜻韭,意味著這將導(dǎo)致數(shù)據(jù)的丟失悼尾。
// 所以柿扣,在正式的項目中肖方,你還應(yīng)該做一層封裝,來實現(xiàn)數(shù)據(jù)庫的安全升級未状。
mHelper = new DaoMaster.DevOpenHelper(this, "notes-db", null);
db = mHelper.getWritableDatabase();
// 注意:該數(shù)據(jù)庫連接屬于 DaoMaster俯画,所以多個 Session 指的是相同的數(shù)據(jù)庫連接。
mDaoMaster = new DaoMaster(db);
mDaoSession = mDaoMaster.newSession();
}
public DaoSession getDaoSession() {
return mDaoSession;
}
public SQLiteDatabase getDb() {
return db;
}
}
附上MainActivity代碼:
public class MainActivity extends AppCompatActivity {? ?
UserDao userDao;? ?
@Override? ?
protected void onCreate(Bundle savedInstanceState) {? ? ?
? super.onCreate(savedInstanceState);? ? ? ?
setContentView(R.layout.activity_main);? ? ?
? //獲取User表單? ? ?
? userDao = MyApplication.getInstances().getDaoSession().getUserDao();? ?
??? User user = new User(null, "YYF");? ? ? ?
userDao.insert(user);? ? ?
? Listusers = userDao.loadAll();
for (int i = 0; i < users.size(); i++) {
Toast.makeText(this, "" + users.get(i).getName(), Toast.LENGTH_SHORT).show();
}
}
}