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;

publicGreenDaoHelpergetInstance(){if(Instance ==null) {        Instance =this;    }returnInstance;}/*** 获取DaoMaster**@paramcontext*@return*/publicstaticDaoMastergetDaoMaster(Context context){if(daoMaster ==null) {try{            DaoMaster.OpenHelper helper =newDaoMaster.DevOpenHelper(context,"test.db",null);            daoMaster =newDaoMaster(helper.getWritableDatabase());//获取未加密的数据库}catch(Exception e){            e.printStackTrace();        }    }returndaoMaster;}/*** 获取DaoSession对象**@paramcontext*@return*/publicstaticDaoSessiongetDaoSession(Context context){if(daoSession ==null) {if(daoMaster ==null) {            getDaoMaster(context);        }        daoSession = daoMaster.newSession();    }returndaoSession;}

}

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

在MainActivity.java中添加读写代码:

public class MainActivity extends AppCompatActivity {

privateTextView textview;privateDaoSession session;@OverrideprotectedvoidonCreate(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 =newArea("01","北京");    Area area1 =newArea("02","天津");    session.getAreaDao().insert(area);    session.getAreaDao().insert(area1);//查询记录StringBuilder stringBuilder =newStringBuilder();    List areas = session.getAreaDao().loadAll();for(inti =0,n = areas.size();i

}

运行结果如下图所示:

修改数据库文件路径:

默认情况下,新创建的数据存储在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;

publicGreenDaoHelpergetInstance(){if(Instance ==null) {        Instance =this;    }returnInstance;}/*** 获取DaoMaster**@paramcontext*@return*/publicstaticDaoMastergetDaoMaster(Context context){if(daoMaster ==null) {try{            ContextWrapper wrapper =newContextWrapper(context) {/**            * 获得数据库路径,如果不存在,则创建对象对象            *            *@paramname            */@OverridepublicFilegetDatabasePath(String name){// 判断是否存在sd卡booleansdExist = android.os.Environment.MEDIA_MOUNTED.equals(android.os.Environment.getExternalStorageState());if(!sdExist) {// 如果不存在,Log.e("SD卡管理:","SD卡不存在,请加载SD卡");returnnull;                }else{// 如果存在// 获取sd卡路径String dbDir = android.os.Environment.getExternalStorageDirectory().getAbsolutePath();                    dbDir +="/Android";// 数据库所在目录String dbPath = dbDir +"/"+ name;// 数据库路径// 判断目录是否存在,不存在则创建该目录File dirFile =newFile(dbDir);if(!dirFile.exists())                        dirFile.mkdirs();// 数据库文件是否创建成功booleanisFileCreateSuccess =false;// 判断文件是否存在,不存在则创建该文件File dbFile =newFile(dbPath);if(!dbFile.exists()) {try{                            isFileCreateSuccess = dbFile.createNewFile();// 创建文件}catch(IOException e) {                            e.printStackTrace();                        }                    }elseisFileCreateSuccess =true;// 返回数据库文件对象if(isFileCreateSuccess)returndbFile;elsereturnsuper.getDatabasePath(name);                }            }/**            * 重载这个方法,是用来打开SD卡上的数据库的,android 2.3及以下会调用这个方法。            *            *@paramname            *@parammode            *@paramfactory            */@OverridepublicSQLiteDatabaseopenOrCreateDatabase(String name,intmode, SQLiteDatabase.CursorFactory factory){returnSQLiteDatabase.openOrCreateDatabase(getDatabasePath(name),null);            }/**            * Android 4.0会调用此方法获取数据库。            *            *@seeandroid.content.ContextWrapper#openOrCreateDatabase(java.lang.String,            *      int,            *      android.database.sqlite.SQLiteDatabase.CursorFactory,            *      android.database.DatabaseErrorHandler)            *@paramname            *@parammode            *@paramfactory            *@paramerrorHandler            */@OverridepublicSQLiteDatabaseopenOrCreateDatabase(String name,intmode, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler){returnSQLiteDatabase.openOrCreateDatabase(getDatabasePath(name),null);            }            };            DaoMaster.OpenHelper helper =newDaoMaster.DevOpenHelper(wrapper,"test.db",null);            daoMaster =newDaoMaster(helper.getWritableDatabase());//获取未加密的数据库}catch(Exception e){            e.printStackTrace();        }    }returndaoMaster;}/*** 获取DaoSession对象**@paramcontext*@return*/publicstaticDaoSessiongetDaoSession(Context context){if(daoSession ==null) {if(daoMaster ==null) {            getDaoMaster(context);        }        daoSession = daoMaster.newSession();    }returndaoSession;}

}

版本升级更新

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

public class Helper extends DaoMaster.OpenHelper{

privatestaticDaoMaster daoMaster;privatestaticDaoSession daoSession;publicstaticfinalString DBNAME ="greendao.db";publicHelper(Context context){super(context,DBNAME,null);}@OverridepublicvoidonUpgrade(Database db,intoldVersion,intnewVersion){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 * *@paramcontext *@return*/publicstaticDaoMastergetDaoMaster(Context context){if(daoMaster ==null) {        DaoMaster.OpenHelper helper =newDaoMaster.DevOpenHelper(context,                DBNAME,null);        daoMaster =newDaoMaster(helper.getWritableDatabase());    }returndaoMaster;}/** * 取得DaoSession * *@paramcontext *@return*/publicstaticDaoSessiongetDaoSession(Context context){if(daoSession ==null) {if(daoMaster ==null) {            daoMaster = getDaoMaster(context);        }        daoSession = daoMaster.newSession();    }returndaoSession;}

}

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;

}

}


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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350