android greendao-2.0.0.jar,Android平台下GreenDao的使用

greenDao的介绍

greenDao是Android数据库ORM(object/relational mapping 对象关系映射的简称)的一个典型代表,其他也有ORMLite等,但greenDao在众多的ORM数据库框架中性能是最好,速度也是最快的,在官方网站中有这个对比,感兴趣的同学可以去看看,greenDao在单位时间内可以插入、更新和查询更多的数据,而且提供了大量的灵活通用接口,文章的最后有个插入的测试,当然删除,修改之类的都是一样快。

操作步骤

greenDao需要一个单独的Java工程,具体可以参考github上的链接greenDao源码,下面是本人的具体步骤:

1.在AndroidStudio中选择File-New Model-Java Library新建一个Java项目,生成表的那个文件默认就好,当然你自己也可以自己决定类的名称,创建完项目之后,在build.gradle文件中添加依赖,下面是build.gradle的内容:

apply plugin: 'java'

dependencies {

compile fileTree(dir: 'libs', include: ['*.jar'])

compile 'de.greenrobot:greendao-generator:1.3.1'

}

其中compile这一句为引入的依赖,然后编写生成框架的类文件,下面是源码

public class MyClass {

public static void main(String[] args) throws Exception {

Schema schema = new Schema(1000, "com.example.db.bean");//这个目录是存放需要建立数据库的bean的地方

schema.setDefaultJavaPackageDao("com.example.dao");//这个是设置包名,就是那个DAO和master存放的路径

addNote(schema);

new DaoGenerator().generateAll(schema, "./greendaoproject/src/main/java-gen");//这个是指定建立greendao存放的目录

}

private static void addNote(Schema schema) {

Entity note = schema.addEntity("Note");//这是一个表名,对应一个实体Note

note.addIdProperty().primaryKey().autoincrement();

note.addStringProperty("text").notNull();

note.addStringProperty("comment");

note.addDateProperty("date");

Entity student = schema.addEntity("Student");

student.addIdProperty().primaryKey().autoincrement();//设置自动增长

student.addStringProperty("name").notNull();

student.addStringProperty("address").notNull();

student.addIntProperty("age");

student.addIntProperty("phonenumber");

student.addStringProperty("imageurl");

student.addStringProperty("author");

Entity account = schema.addEntity("Account");

account.addIdProperty().autoincrement();

account.addStringProperty("name").notNull();

account.addStringProperty("address").notNull();

account.addStringProperty("number").notNull();

}

}

其中,重要的有那么几句代码:

Schema schema = new Schema(1000, "com.example.db.bean");//这里面第一个参数是版本,第二个参数是存放具体业务bean的地方,比如学生实体,账户实体等

new DaoGenerator().generateAll(schema, "./greendaoproject/src/main/java-gen"); 第二个参数很重要,它代表的是生成那些greenDao中的Dao存放的目录,这个参数可以是绝对路径,也可以是相对路径,但必须存在,可以看到放在了另一个项目的java-gen目录下面,于是新建greendaoproject项目,并在main目录下新建java-gen目录,下面是截图:

看到没,红框的地方就是刚才代码生成的,当然需要执行那个类,如果没有错误就会生成这样一个目录,除此之外,还需要在greendaoproject中指定这个java-gen为源码路径,下面是build.gradle中的指定代码:

然后 同步sync一下,就可以看到目录的颜色跟java一样的了,这代表已经加入了源码路径了。

好了,准备工作已经做好了,现在看看那个目录到底有啥内容吧,前面说过了,加入了3个实体,按道理会生成3个Dao和3个bean,并在指定的路径,实际上确实如此,下面是截图:

看到了吧,自动生成了,其中还生成了DaoMaster和DaoSession,这两个类一般是全局的,官方推荐在自定义的Application中初始化,这样就避免了多次初始化,下面是在自定义的applicaiton中初始化数据库以及获取各种Dao的代码

public class BaseApplication extends Application {

private static BaseApplication mInstance;

//db

private SQLiteDatabase db;

private static DaoMaster daoMaster;

private static DaoSession daoSession;

@Override

public void onCreate() {

super.onCreate();

if (mInstance == null) {

mInstance = this;

}

DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this, GlobalConfig.DB_NAME, null);

db = helper.getWritableDatabase();

daoMaster = new DaoMaster(db);

daoSession = daoMaster.newSession();

}

public static BaseApplication getInstance() {

return mInstance;

}

public static void setmInstance(BaseApplication mInstance) {

BaseApplication.mInstance = mInstance;

}

public SQLiteDatabase getDb() {

return db;

}

public void setDb(SQLiteDatabase db) {

this.db = db;

}

public static DaoMaster getDaoMaster() {

return daoMaster;

}

public static void setDaoMaster(DaoMaster daoMaster) {

BaseApplication.daoMaster = daoMaster;

}

public static DaoSession getDaoSession() {

return daoSession;

}

public static void setDaoSession(DaoSession daoSession) {

BaseApplication.daoSession = daoSession;

}

public AccountDao getAccountDao() {

return daoSession.getAccountDao();

}

public NoteDao getNoteDao() {

return daoSession.getNoteDao();

}

public StudentDao getStudentDao() {

return daoSession.getStudentDao();

}

}

看到没,首先用DaoMaster的DevOpenHelper获取一个helper,然后用这个helper打开一个实际操作的数据库db ,之后把这个db作为参数传进DaoMaster获取一个DaoMaster,之后用daoMaster获取daoSession,有了daoSession,各种业务Dao就可以写个方法获取了,因为DaoSession管理了所有的Dao,写完之后记得注册自定义的application,好了,下面是开始测试了,我这里只是测试了插入,当然,其他都是一样的,新建一个activity,并写如下代码测试,我这边是测试5000条数据

public class MainActivity extends AppCompatActivity {    private Listlist=new ArrayList<>();

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

for(int i=0;i<5000;i++){

Account account=new Account();

account.setAddress("测试地址"+i);

account.setName("你好啊,我擦"+i);

account.setNumber("这是号码"+i);

list.add(account);

}

long start=System.currentTimeMillis();

AccountDao accountDao=BaseApplication.getInstance().getAccountDao();

accountDao.insertInTx(list);

long end=System.currentTimeMillis();

Log.d("[app]","耗时为:"+(end-start));

}

}

结果怎样呢,我这边测试了10次,结果如下:

看到没,10次测试,5000条数据,平均在500毫秒左右,比ORMLite快多了,ORMLite是利用反射完成的,需要耗费一点性能,有人会说假如有10万条数据,那岂不是很耗时,呵呵,如果有十万条数据,没必要全部一次性存储,分开存储,就是先存储5000条,然后再存储5000条,这样就好,当然了你可以开一个线程去存储,毕竟你不可能一下子展示10万条数据,对吧,当你看完前面的5000条数据的时候,剩下的95000条数据早已经插入数据库啦,这个时候直接获取再展示就好了。好了,今天就写到这儿吧,各位多去实践,多去测试就知道greenDao有多优秀的ORM框架了。

备注:

通常情况下,数据库作为缓存的最佳选择,当然除了数据库,文件也是一个不错的选择,但文件在存储大量数据的时候性能很低的,在项目中,我都是利用greendao来实现收藏功能,就是获取到数据之后先存储在本地,然后需要的时候再获取显示,当然除了收藏功能,其他需要利用缓存的地方也是可以使用greenDao的,因为任何业务都是以对象的形式存在的,即使不是对象,我们也可以构造对象进行存储。

你可能感兴趣的:(android)