引入依赖
implementation 'org.greenrobot:greendao:3.2.2'
implementation 'com.github.yuweiguocn:GreenDaoUpgradeHelper:v2.1.0' //升级迁移数据库时使用
在根目录下的build.gradle文件的buildscript-》dependencies 里加入
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
在app目录下的build.gradle文件加入
apply plugin: 'org.greenrobot.greendao'
android 标签下加入
greendao {
schemaVersion 1 //版本号
daoPackage 'com.test.testapp.greendao.gen' //dao生成位置
targetGenDir 'src/main/java' //设置DaoMaster、DaoSession、Dao目录
}
创建实体类
@Entity public class User { @Id @Unique private String id; private String username; private String name; private Integer sex; }
在application里进行初始化操作
public class MyApp extends Application{ public static MyApp instance; private SQLiteDatabase db; private DaoSession mDaoSession; @Override public void onCreate() { instance = this; setDatabase(); } public static MyApp getInstances(){ return instance; } private void setDatabase() { // 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。 // 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO已经帮你做了。 // 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。 // 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。 // mHelper = new DaoMaster.DevOpenHelper(this, "test.db", null); DBHelper mHelper = new DBHelper(this, "text.db", null); db = mHelper.getWritableDatabase(); // 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。 DaoMaster mDaoMaster = new DaoMaster(db); mDaoSession = mDaoMaster.newSession(); } public DaoSession getDaoSession() { return mDaoSession; } } public class DBHelper extends DaoMaster.OpenHelper { public DBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) { super(context, name, factory); } @Override public void onUpgrade(Database db, int oldVersion, int newVersion) { super.onUpgrade(db, oldVersion, newVersion); /** * com.github.yuweiguocn:GreenDaoUpgradeHelper:v2.1.0 * 安全更新数据库 * UserDao.class * 这些是安全更新的表的dao * 需要安全更新的数据表都dao要放到这里 */ MigrationHelper.migrate(db, new MigrationHelper.ReCreateAllTableListener() { @Override public void onCreateAllTables(Database db, boolean ifNotExists) { DaoMaster.createAllTables(db, ifNotExists); } @Override public void onDropAllTables(Database db, boolean ifExists) { DaoMaster.dropAllTables(db, ifExists); } },UserDao.class); } }
执行编译操作相应的类就自动生成好了 DaoMaster DaoSession 相关的dao类这里是 UserDao 还有User的set get方法和构造器都生成好了
下面可以进行数据库操作了
UserDao userDao = MyApp.getInstances().getDaoSession().getUserDao(); userDao.insertOrReplace(user); List list = userDao.queryBuilder() .where(UserDao.Properties.Name.eq("张三")).offset(0) .limit(20).orderDesc(UserDao.Properties.Name).list();
其他方法查看AbstractDao类即可