使用:
在你project项目的build.gradle配置以下:
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
}
}java
// 使用数据库升级辅助GreenDaoUpgradeHelper时添加
allprojects {
repositories {
maven { url "https://jitpack.io" }
}
}android
在你的modules 里app/build.gradle里配置以下:git
apply plugin: 'org.greenrobot.greendao'github
dependencies {
compile 'org.greenrobot:greendao:3.2.2'sql
// 使用数据库加密时添加 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;session
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; }
}
在读写数据库以前,要添加读写权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
在MainActivity.java中添加读写代码:
public class MainActivity extends AppCompatActivity {app
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); }
}
运行结果以下图所示:maven
修改数据库文件路径:
默认状况下,新建立的数据存储在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;
}
/**
//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;}}