DaoManger
package com.bwie.grenndao;
import android.content.Context;
import com.bwie.grenndao.GreenDao.DaoMaster;
import com.bwie.grenndao.GreenDao.DaoSession;
public class DaoManger {
private static DaoManger daoManger;
private DaoSession daoSession;
private DaoManger(Context context){
daoSession = DaoMaster.newDevSession(context, “person.db”);
}
public static DaoManger getInstance(Context context){
if (daoMangernull){
synchronized (DaoManger.class){
if (daoMangernull){
daoManger=new DaoManger(context);
}
}
}
return daoManger;
}
public DaoSession getDaoSession(){
return daoSession;
}
}
MAinActivity
package com.bwie.grenndao;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import com.bwie.grenndao.GreenDao.DaoSession;
import com.bwie.grenndao.GreenDao.personDao;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private DaoSession daoSession;
private personDao personDa;
private int index;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
daoSession = DaoManger.getInstance(this).getDaoSession();
personDa= daoSession.getPersonDao();
}
public void query(View view) {
List<person> list = personDa.queryBuilder()
.where(personDao.Properties.Age.lt(500))
.orderDesc(personDao.Properties.Age)
.build()
.list();
for (person person: list) {
Log.e("tag",person.toString());
}
}
public void add(View view) {
index++;
person person = new person(null, "name" + index, index*10);
personDa.insert(person);
}
public void update(View view) {
List<person> list = personDa.queryBuilder()
.where(personDao.Properties.Age.lt(500))
.orderDesc(personDao.Properties.Age)
.build()
.list();
for (person person: list){
if (person.age==20){
person.age=100;
personDa.update(person);
}
}
}
public void delete(View view) {
person person = personDa.queryBuilder()
.where(personDao.Properties.Age.eq(2))
.build()
.unique();
if (person!=null){
personDa.delete(person);
}
}
}
PerSon类
package com.bwie.grenndao;
import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Property;
import org.greenrobot.greendao.annotation.Transient;
import org.greenrobot.greendao.annotation.Generated;
@Entity(nameInDb = “person_table”)
public class person {
@Id(autoincrement = true)
public Long id;
@Property(nameInDb = “name”)
public String mingzi;
public int age;
@Transient
public String identity;
@Generated(hash = 147018472)
public person(Long id, String mingzi, int age) {
this.id = id;
this.mingzi = mingzi;
this.age = age;
}
@Generated(hash = 935979889)
public person() {
}
public Long getId() {
return this.id;
}
public void setId(Long id) {
this.id = id;
}
public String getMingzi() {
return this.mingzi;
}
public void setMingzi(String mingzi) {
this.mingzi = mingzi;
}
public int getAge() {
return this.age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "person{" +
"id=" + id +
", mingzi='" + mingzi + '\'' +
", age=" + age +
", identity='" + identity + '\'' +
'}';
}
}
greendao{
schemaVersion 1 // 数据库版本号
daoPackage ‘com.bwie.grenndao.GreenDao’//greenDao 自动生成的代码保存的包名
targetGenDir ‘src/main/java’ //自动生成的代码存储的路径,默认是 build/generated/source/greendao.
generateTests false //true的时候自动生成测试单元
//targetGenDirTests: 测试单元的生成目录默认是 src/androidTest/java
}
apply plugin: ‘org.greenrobot.greendao’