今天用到了GreenDao数据查询,非常的简单,就是刚开始配置的时候有点小麻烦,用起来还是可以的,总之不用再去写sql语句了,!
接下来就给大家带来GreenDao的配置:
在App.build中:
apply plugin: 'org.greenrobot.greendao'
然后写入版本信息,同时要是升级版本号,直接就可以将1改变就可以了,很简单的,版本号下边,就是自己的包名,改一下就行,后边.gen就是要生的文件
greendao {
schemaVersion 1
daoPackage 'com.bwie.test.greendaotext.gen'
targetGenDir 'src/main/java'
}
然后在下方导入依赖:
compile 'org.greenrobot:greendao:3.2.0'
mavenCentral()
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'
好了,到这里就配置完成了,也是很简单的,是吧!
下来就是简单的代码了,
首先创建一个User类:这里边就好比要写的字段,一个ID,一个username,一个age,名字同样可以用代码来写,
@Id(autoincrement = true)// 是否自动增长 @ID:表示为主键
private Long ID;
@Property(nameInDb = "USERNAME") // @Property:在数据库中,会对应生成一个字段,nameInDb:字段名称
private String username;
@Property(nameInDb = "AGE")
private int age;
这个类创建完成之后,就可以运行了,会自动给你生成
接下来,在MainActivity中,就要进行简单的操作了,首先是初始化GreenDao:,几行代码,
DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(MainActivity.this, "notes-db", null);
DaoMaster daoMaster = new DaoMaster(devOpenHelper.getWritableDb());
DaoSession daoSession = daoMaster.newSession();
UserDao mUserDao = daoSession.getUserDao();
增加数据:
// 添加
for (int i = 0; i < 10; i++){
User user = new User(null,"lzy"+"44",444);
mUserDao.insert(user);
}
删除数据:(删除全部数据,直接将user对象放进去就是可了,)
userDao.delete(user);
删除单个:
mUserDao.deleteByKey((long) 50);
(删除部分数据,有条件的删除:首先就要查询了,并且是有条件的查询,将查询下来的集合对象直接删除就可以了、)
先看查询:(where中就是要查询的条件),查询完之后,直接删除集合就可以
List<User> list = mUserDao.queryBuilder().where(UserDao.Properties.ID.le(10)).build().list();
for (int i = 0; i<list.size();i++){
Log.d("main--",list.get(i).toString()+"==");
}
查询完成之后就可以 删除了:
删除集合:
mUserDao.deleteInTx(list);
修改数据:
具体修改哪一个:
User user3 = new User((long) 30,"梁旭东",40);
mUserDao.update(user3);
// 将查询出来的集合,下标为25的姓名更改
list.get(5).setUsername("李泽阳");
mUserDao.update(list.get(5));
好了,GreenDao的简单的集成就到这里了,希望对大家有用。
谢谢~~