使用:
在你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 {
private String AreaCode;
private String AreaName;
}
最后,Build->Make Module 'app',即可自动生成DaoMaster、DaoSession、Area和AreaDao。此时Area实体类的代码如下:
public class Area {
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;
}
在读写数据库之前,要添加读写权限:
在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;
}
}
喜欢的点个赞或者关注哦,你的关注和点赞是我最大的支持和鼓励,谢谢,加油