GreenDao数据库

1.倒依赖

//根gradle 

classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'

//app gradle

apply plugin: 'org.greenrobot.greendao' 

greendao {

 schemaVersion 1 //数据库版本号   

  daoPackage '包名.database' //设置时生成代码的目录   

  targetGenDir 'src/main/java' //设置DaoMaster、DaoSession、Dao目录

 }

dependencies {  

  compile 'org.greenrobot:greendao:3.2.2' 

}

2.Preson里写

@Entity(nameInDb = "preson")

  @Id(autoincrement = true)

    private Long id;

 @Property(nameInDb = "name")

    private String name1;

重编译

3.写DaoManager单例模式

public class DaoManager {
    private static DaoManager daoManager;
    private final DaoSession daoSession;
    private DaoManager(Context context) {
        daoSession = DaoMaster.newDevSession(context, "my.db");
    }
    public static DaoManager instance(Context context) {
        if (daoManager == null) {
            synchronized (DaoManager.class) {
                if (daoManager == null) {
                    daoManager = new DaoManager(context);
                }
            }
        }
        return daoManager;
    }
    public DaoSession getDaoSession() {
        return daoSession;
    }

}

4.数据库操作增删改查

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        daoSession = DaoManager.instance(this).getDaoSession();
        personDao = daoSession.getPersonDao();
    }
    public void add(View view) {
        index++;
        personDao.insert(new Person(null, "wang" + index, index));
    }
    public void delete(View view) {
        Person person = personDao.queryBuilder()
                .where(PersonDao.Properties.Id.eq(1))
                .build().unique();
        personDao.delete(person);
    }
    public void update(View view) {
        Person person = personDao.queryBuilder()
                .where(PersonDao.Properties.Id.eq(1))
                .build().unique();
        person.setAge(1000);
        personDao.update(person);
    }
    public void query(View view) {
        List<Person> list = personDao.queryBuilder()
                .where(PersonDao.Properties.Id.ge(5))
                .build().list();
        Log.e("tag", "query" + list.get(0).getId());
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值