android geendao简单使用
引入依赖
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类即可
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端