依赖:
implementation 'org.greenrobot:greendao:3.2.2' implementation 'org.greenrobot:greendao-generator:3.2.2'
在Module的build.gradle中配置:
apply plugin: 'org.greenrobot.greendao' android { ......省略 greendao { schemaVersion 1 daoPackage 'com.example.Test.model.greendao' targetGenDir 'src/main/java' } }
在projet的build.gradle中配置:
dependencies { ....... classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' }
greenDao的配置:
schemaVersion---->指定数据库schema版本号,迁移等操作会用到
daoPackage-------->通过gradle插件生成的数据库相关文件(设置DaoMaster、DaoSession、Dao包名,也就是要放置这些类的包的全路径。),这里我设置的文件路径是com.example.Test.model.greendao
targetGenDir-------->这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目
在项目里面添加实体类如下:
@Entity public class User { @Id private Long id; private String name; }
然后点击 android studio 的 build-->make project
操作数据库:
// 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。 // 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。 // 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。 // 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。 DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(context,"db",null);//数据库名 SQLiteDatabase database = devOpenHelper.getWritableDatabase(); // 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。 DaoMaster daoMaster = new DaoMaster(database); DaoSession daoSession = daoMaster.newSession(); UserDao userDao = daoSession.getUserDao();
db是数据库的名字,自己随便写就行。
通过GreenDao生成的代码,我们可以获取到实体类的实例,也就是数据库表的实例,这样我们才能操作数据库
1、增加
User user1 = new User(null,"zhangsan"); userDao.insert(user1);
2、删除
User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("zhangsan")).build().unique(); if(findUser != null){ userDao.deleteByKey(findUser.getId()); }
3、修改
User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("zhangsan")).build().unique(); if(findUser != null) { findUser.setName("lisi"); userDao.update(findUser); Toast.makeText(MyApplication.getContext(), "修改成功", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(MyApplication.getContext(), "用户不存在", Toast.LENGTH_SHORT).show(); }
把zhangsan改成lisi
4、查询
List<User> userList = userDao.queryBuilder() .where(UserDao.Properties.Id.notEq(1)) .limit(5) .build().list();
查询语句是数据库操作最多的,语句也比较复杂,具体的语句请去看官网