Android平台下

作者: K线中有财富密码 | 来源:发表于2016-05-01 11:47 被阅读722次

    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平台下

        本文链接:https://www.haomeiwen.com/subject/jbgkrttx.html