Android 高效的SQLite型数据库greenDAO使用

Stella981
• 阅读 753

Android 高效的SQLite型数据库greenDAO使用

使用:
在你project项目的build.gradle配置如下:
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath ‘org.greenrobot:greendao-gradle-plugin:3.2.2’
}
}

// 使用数据库升级辅助GreenDaoUpgradeHelper时添加
allprojects {
repositories {
maven { url “https://jitpack.io” }
}
}

在你的modules 里app/build.gradle里配置如下:

apply plugin: ‘org.greenrobot.greendao’

dependencies {
compile ‘org.greenrobot:greendao:3.2.2’

// 使用数据库加密时添加
compile ‘net.zetetic:android-database-sqlcipher:3.5.6’

// 使用数据库升级辅助GreenDaoUpgradeHelper时添加
compile ‘com.github.yuweiguocn:GreenDaoUpgradeHelper:v2.0.1’

}

greendao {
schemaVersion 1
daoPackage 'com.greendao.db
targetGenDir ‘src/main/java’
}

 首先,新建datamodel包,用以包含DaoMaster、DaoSession、bean和beanDao等。br/>     然后新建Area实体类,代码如下:

@Entity
public class Area {br/>@Id
private String AreaCode;
private String AreaName;
}
最后,Build->Make Module ‘app’,即可自动生成DaoMaster、DaoSession、Area和AreaDao。此时Area实体类的代码如下:br/>@Entity
public class Area {br/>@Id
private String AreaCode;
private String AreaName;
@Generated(hash = 262290694)
public Area(String AreaCode, String AreaName) {
this.AreaCode = AreaCode;
this.AreaName = AreaName;
}
@Generated(hash = 179626505)
public Area() {
}
public String getAreaCode() {
return this.AreaCode;
}
public void setAreaCode(String AreaCode) {
this.AreaCode = AreaCode;
}
public String getAreaName() {
return this.AreaName;
}
public void setAreaName(String AreaName) {
this.AreaName = AreaName;
}
}
添加其他实体类的方法与Area一样。需要注意的是,不要手动修改DaoMaster、DaoSession、bean和beanDao的代码,因为每一次编译项目,都会重新生成一次DaoMaster、DaoSession、bean和beanDao。如果修改的话,就会被覆盖掉。
为了便于数据的读取和添加,新建GreenDaoHelper辅助类,代码如下:
public class GreenDaoHelper extends Application {
private GreenDaoHelper Instance;
private static DaoMaster daoMaster;
private static DaoSession daoSession;

public GreenDaoHelper getInstance() {
if (Instance == null) {
Instance = this;
}
return Instance;
}

/**

  • 获取DaoMaster

  • @param context

  • @return
    */
    public static DaoMaster getDaoMaster(Context context) {
    if (daoMaster == null) {
    try{
    DaoMaster.OpenHelper helper = new DaoMaster.DevOpenHelper(context,“test.db”,null);
    daoMaster = new DaoMaster(helper.getWritableDatabase()); //获取未加密的数据库
    }catch (Exception e){
    e.printStackTrace();
    }
    }
    return daoMaster;
    }

/**

  • 获取DaoSession对象

  • @param context

  • @return
    */
    public static DaoSession getDaoSession(Context context) {

    if (daoSession == null) {
    if (daoMaster == null) {
    getDaoMaster(context);
    }
    daoSession = daoMaster.newSession();
    }
    return daoSession;
    }

}
在读写数据库之前,要添加读写权限:

在MainActivity.java中添加读写代码:
public class MainActivity extends AppCompatActivity {

private TextView textview;
private DaoSession session;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

textview=(TextView)findViewById(R.id.textview);

session = GreenDaoHelper.getDaoSession(this);
session.getAreaDao().deleteAll();//清空所有记录

//添加记录
Area area = new Area("01","北京");
Area area1 = new Area("02","天津");
session.getAreaDao().insert(area);
session.getAreaDao().insert(area1);

//查询记录
StringBuilder stringBuilder = new StringBuilder();
List<Area> areas = session.getAreaDao().loadAll();
for (int i = 0,n = areas.size();i<n;++i){
    stringBuilder.append("地区编码:").append(areas.get(i).getAreaCode())
            .append(",地区名称:").append(areas.get(i).getAreaName()).append("\n");
}

textview.setText(stringBuilder);

}

}
运行结果如下图所示:

修改数据库文件路径:
默认情况下,新创建的数据存储在data的包名目录下,设备如果不root的话,是无法查看SQLite数据库文件的。而实际应用中,我们往往需要copy数据库,或借用第三方工具查阅或编辑数据库内容。此时我们可以通过重写Context的getDatabasePath(String name)、openOrCreateDatabase(String name, int mode, CursorFactory factory)、openOrCreateDatabase(String name, int mode, CursorFactory factory, DatabaseErrorHandler errorHandler)等三个方法来修改SQLite文件的存储路径。

public class GreenDaoHelper extends Application {
private GreenDaoHelper Instance;
private static DaoMaster daoMaster;
private static DaoSession daoSession;

public GreenDaoHelper getInstance() {
if (Instance == null) {
Instance = this;
}
return Instance;
}

/**

  • 获取DaoMaster

  • @param context

  • @return
    */
    public static DaoMaster getDaoMaster(Context context) {

    if (daoMaster == null) {

      try{
          ContextWrapper wrapper = new ContextWrapper(context) {
          /**
          * 获得数据库路径,如果不存在,则创建对象对象
          *
          * @param name
          */
          @Override
          public File getDatabasePath(String name) {
              // 判断是否存在sd卡
              boolean sdExist = android.os.Environment.MEDIA_MOUNTED.equals(android.os.Environment.getExternalStorageState());
              if (!sdExist) {// 如果不存在,
                  Log.e("SD卡管理:", "SD卡不存在,请加载SD卡");
                  return null;
              } else {// 如果存在
                  // 获取sd卡路径
                  String dbDir = android.os.Environment.getExternalStorageDirectory().getAbsolutePath();
                  dbDir += "/Android";// 数据库所在目录
                  String dbPath = dbDir + "/" + name;// 数据库路径
                  // 判断目录是否存在,不存在则创建该目录
                  File dirFile = new File(dbDir);
                  if (!dirFile.exists())
                      dirFile.mkdirs();
    
                  // 数据库文件是否创建成功
                  boolean isFileCreateSuccess = false;
                  // 判断文件是否存在,不存在则创建该文件
                  File dbFile = new File(dbPath);
                  if (!dbFile.exists()) {
                      try {
                          isFileCreateSuccess = dbFile.createNewFile();// 创建文件
                      } catch (IOException e) {
                          e.printStackTrace();
                      }
                  } else
                      isFileCreateSuccess = true;
                  // 返回数据库文件对象
                  if (isFileCreateSuccess)
                      return dbFile;
                  else
                      return super.getDatabasePath(name);
              }
          }
    
          /**
          * 重载这个方法,是用来打开SD卡上的数据库的,android 2.3及以下会调用这个方法。
          *
          * @param name
          * @param mode
          * @param factory
          */
          @Override
          public SQLiteDatabase openOrCreateDatabase(String name, int mode, SQLiteDatabase.CursorFactory factory) {
              return SQLiteDatabase.openOrCreateDatabase(getDatabasePath(name), null);
          }
    
          /**
          * Android 4.0会调用此方法获取数据库。
          *
          * @see android.content.ContextWrapper#openOrCreateDatabase(java.lang.String,
          *      int,
          *      android.database.sqlite.SQLiteDatabase.CursorFactory,
          *      android.database.DatabaseErrorHandler)
          * @param name
          * @param mode
          * @param factory
          * @param errorHandler
          */
          @Override
          public SQLiteDatabase openOrCreateDatabase(String name, int mode, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler) {
              return SQLiteDatabase.openOrCreateDatabase(getDatabasePath(name), null);
          }
          };
          DaoMaster.OpenHelper helper = new DaoMaster.DevOpenHelper(wrapper,"test.db",null);
          daoMaster = new DaoMaster(helper.getWritableDatabase()); //获取未加密的数据库
      }catch (Exception e){
          e.printStackTrace();
      }
    

    }
    return daoMaster;
    }

/**

  • 获取DaoSession对象

  • @param context

  • @return
    */
    public static DaoSession getDaoSession(Context context) {

    if (daoSession == null) {
    if (daoMaster == null) {
    getDaoMaster(context);
    }
    daoSession = daoMaster.newSession();
    }

    return daoSession;
    }

}

版本升级更新
比如需要在实体类加一个字段 或者 改变字段属性等 就需要版本更新来保存以前的数据了;

public class Helper extends DaoMaster.OpenHelper{

private static DaoMaster daoMaster;
private static DaoSession daoSession;

public static final String DBNAME = “greendao.db”;

public Helper(Context context){
super(context,DBNAME,null);
}

@Override
public void onUpgrade(Database db, int oldVersion, int newVersion) {
super.onUpgrade(db, oldVersion, newVersion);
Log.i(“version”, oldVersion + “—先前和更新之后的版本—” + newVersion);
if (oldVersion < newVersion) {
Log.i(“version”, oldVersion + “—先前和更新之后的版本—” + newVersion);
MigrationHelper.getInstance().migrate(db, UserDao.class);
//更改过的实体类(新增的不用加) 更新UserDao文件 可以添加多个 XXDao.class 文件

// MigrationHelper.getInstance().migrate(db, UserDao.class,XXDao.class);
}
}

/**

  • 取得DaoMaster

  • @param context

  • @return
    */
    public static DaoMaster getDaoMaster(Context context) {
    if (daoMaster == null) {
    DaoMaster.OpenHelper helper = new DaoMaster.DevOpenHelper(context,
    DBNAME, null);
    daoMaster = new DaoMaster(helper.getWritableDatabase());
    }
    return daoMaster;
    }

/**

  • 取得DaoSession

  • @param context

  • @return
    */
    public static DaoSession getDaoSession(Context context) {
    if (daoSession == null) {
    if (daoMaster == null) {
    daoMaster = getDaoMaster(context);
    }
    daoSession = daoMaster.newSession();
    }
    return daoSession;
    }

}

public class GreenApplication extends Application {
private DaoMaster.DevOpenHelper mHelper;
//private Helper mHelper;
private SQLiteDatabase db;
private DaoMaster mDaoMaster;
private DaoSession mDaoSession;
public static GreenApplication instances;
@Override public void onCreate() {
super.onCreate();
instances = this;
setDatabase();
}
public static GreenApplication getInstances(){
return instances;
}

/**
•设置greenDao
*/
private void setDatabase() {
// 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。
// 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。
// 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。
// 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。
   mHelper = new Helper(new GreenDaoUtils(this));

//mHelper = new DaoMaster.DevOpenHelper(this, “notes-db”, null);
db = mHelper.getWritableDatabase();
// 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。
mDaoMaster = new DaoMaster(db);
mDaoSession = mDaoMaster.newSession();
}
public DaoSession getDaoSession() {
return mDaoSession;
}
public SQLiteDatabase getDb() {
return db;
}
}

个人简书地址:https://www.jianshu.com/p/7e86dea00f4f

个人技术博客地址:https://blog.51cto.com/1206995290qq/2460710

喜欢的点个赞或者关注哦,你的关注和点赞是我最大的支持和鼓励,谢谢,加油

Android 高效的SQLite型数据库greenDAO使用

Android 编程开发视频教学 哔哩哔哩号:

Android 高效的SQLite型数据库greenDAO使用

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这