当前位置:首页 » 数据仓库 » greendao升级数据库
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

greendao升级数据库

发布时间: 2022-04-20 16:37:40

A. android app开发中常用到哪些开源框架

在前面的课程中,随着对Android体系的了解,已经可以进行正常的Android应用开发了。在Android开发中,同其他工程开发一样,也经常使用一些提高效率的框架,本文我们做一个对比。这些框架,既包括:网络请求框架、也包括图片加载库框架、还包括数据库操作等一些框架,总之,了解和熟悉这些框架,会对自己的开发效率有很大的提升和帮助。

网络请求框架

1、okHttp

在前文的学习中,我们已经了解过okHttp,是一个常用的网络加载库。

2、Retrofit

介绍

Retrofit是一个很不错的网络请求库,该库是square开源的另外一个库,之前的okhttp也是该公司开源的。

Retrofit是基于OkHttp封装的RESTful网络请求框架,使用注解的方式配置请求。优点是速度快,使用注解,callback函数返回结果自动包装成Java对象。官方自己的介绍说:

A type-safe REST client for Android and Java

该网络框架在github上的地址如下:https://square.github.io/retrofit/

要求

Retrofit支持的http方式方式包括 GET/POST/PUT/DELETE/HEAD/PATCH,Retrofit要求Java的版本是1.8+,Android应用的API版本应该在21+。

依赖

使用Retrofit库,和其他库一样,首先需要设置依赖,依然是在build.gradle文件中设置依赖:

//添加retrofit库依赖

implementation ‘com.squareup.retrofit2:retrofit:2.1.0’

//添加gson转换器

implementation ‘com.squareup.retrofit2:converter-gson:2.1.0’

使用

通过一个例子,我们可以来演示该框架的使用步骤:

1、定义请求接口,即程序中都需要什么请求操作
public interface HttpServices {

/**

  • 获取头条新闻

  • @param type 新闻类型

  • @param key apiKey

  • @return

  • */

    @GET(“toutiao/index”)

    Call getNewsList(@Query(“type”) String type, @Query(“key”) String key);

    }

    2、实例化Retrofit对象,使用的Builder的模式创建,如下代码所示:
    Retrofit retrofit = new Retrofit.Builder()

    .baseUrl(Constants.BASE_API)

    .addConverterFactory(GsonConverterFactory.create())

    .build();

    注意,这里设置结构体转换器,是可以直接把网络请求回来的数据转换为Java结构体,这里设置的Gson解析器,因此要引入相应的转换器支持库。

    3、得到接口对象,自己创建的全局的接口对象,并调用相应的接口,得到一个类似于请求Call对象。如下所示:
    HttpServices httpServices = retrofit.create(HttpServices.class);

    Call newsListCall = httpServices.getNewsList(“top”, Constants.API_KEY);

    4、加入到请求队列中,并设置回调方法:
    newsListCall.enqueue(new Callback() {

    @Override

    public void onResponse(Call call, Response response) {

    //网络请求成功的回调方法

    List list = Arrays.asList(response.body().result.data);

    Log.i(“TAG”, “请求成功:” + String.valueOf(list.size()));

    NewListAdapter adapter = new NewListAdapter(RetrofitActivity.this);

    adapter.setmData(list);

    mRecyclerView.setAdapter(adapter);

    }

    @Override

    public void onFailure(Call call, Throwable throwable) {

    //网络请求失败的回调方法

    Log.i(“TAG”, “请求失败:” + throwable.getMessage());

    }

    });

    其他界面操作和之前的Android中的内容一致。

    3、RxJava

    简单来说,用来处理事件和异步任务,在很多语言上都有实现,RxJava是Rx在Java上的实现。

    原理

    RxJava最基本的原理是基于观察者模式来实现的。通过Obserable和Observer的机制,实现所谓响应式的编程体验。

    特点

    RxJava在编程中的实现就是一种链式调用,做了哪些操作,谁在前谁在后非常直观,逻辑清晰,代码维护起来非常轻松。

    RxJava也是一个在github上的库,githubhttp://www.xingkongmj.com/news/id/62.html地址如下:https://github.com/ReactiveX/RxJava

    基于此,还有一个RxAndroid,github地址如下:https://github.com/ReactiveX/RxAndroid

    RxJava和RxAndroid的关系

    RxAndroid是RxJava的一个针对Android平台的扩展,主要用于 Android 开发。

    基本概念

    RxJava 有四个基本概念:

    Observable:可观察者,即被观察者Observer:观察者subscribe:订阅事件
    这四个概念之间的逻辑关系是:Observable和Observer通过subscribe方法实现订阅关系,从而Observable可以在需要的时候发出事件来通知Observer。

    事件

    RxJava 的事件回调方法主要包含以下几个:

    onNext:普通的事件onCompletedhttp://dachang.net/432717.html:事件队列完结。RxJava 不仅把每个事件单独处理,还会把它们看做一个队列。RxJava 规定,当不会再有新的 onNext 发出时,需要触发 onCompleted 方法作为标志。:事件队列异常。在事件处理过程中出异常时, 会被触发,同时队列自动终止,不再允许再有事件发出。在一个正确运行的事件序列中, onCompleted和 有且只有一个,并且是事件序列中的最后一个。需要注意的是,onCompleted() 和 () 二者也是互斥的,即在队列中调用了其中一个,就不应该再调用另一个。
    数据库操作框架

    在开发时,本地数据库可以起到缓存数据和存储业务数据的作用,随着技术的成熟,不断推出了有很多关于数据库的操作框架。比较常见的数据库操作框架有诸如:GreenDao,OrmLite 和 ActiveAndroid,DBFlow等。

    GreenDAO

    GreenDAO是一个开源的 Android ORM(“对象/关系映射”),通过 ORM(称为“对象/关系映射”),在我们数据库开发过程中节省了开发时间!

    GreenDao的官方文档地址如下:http://www.xingkongmj.com/news/id/63.html

    GreenDao的作用

    通过 GreenDao,我们可以更快速的操作数据库,我们可以使用简单的面相对象的API来存储,更新,删除和查询 Java 对象。这款数据库操作框架的特点是:

    高性能,在官方的统计数据中,GreenDao在GreenDao,OrmLite 和 ActiveAndroid三个框架中,读、写、更新操作效率均表现第一。易于使用的强大 API,涵盖关系和连接。内存消耗较小。安全:greenDAO 支持 sqlCipherhttp://www.xingkongmj.com/news/id/64.html,以确保用户的数据安全;
    核心概念

    GreenDao 的核心类有三个:分别是:

    DaoMaster:保存数据库对象(SQLiteDatabase)并管理特定模式的 DAO 类(而不是对象)。它有静态方法来创建表或删除它们。它的内部类 OpenHelper 和DevOpenHelper 是 SQLiteOpenHelper 实现,它们在 SQLite 数据库中创建模式。DaoSession:管理特定模式的所有可用 DAO 对象,您可以使用其中一个getter方法获取该对象。DaoSession 还提供了一些通用的持久性方法,如实体的插入,加载,更新,刷新和删除。XXXDao:数据访问对象(DAO)持久存在并查询实体。对于每个实体,greenDAO 生成DAO。它具有比 DaoSession 更多的持久性方法。Entities:可持久化对象。通常, 实体对象代表一个数据库行使用标准 Java 属性(如一个POJO 或 JavaBean )。
    使用

    按照官方的文档和github上的说明可以实现green的使用。

    首先进行的是依赖,对于greenDao,有两个地方需要设置,分别是项目根目录中的 build.gradle,还有mole中的build.gradle。
    classpath ‘org.greenrobot:green-gradle-plugin:3.3.0’ // add plugin

    在项目根目录中的build.gradle目录中写这句话的意思是添加greenDao的插件。

    在项目mole中的build.gradle中也需要进行配置,有两个地方需要设置,如下图所示:

    apply plugin: ‘org.greenrobot.greenhttp://www.xingkongmj.com/news/id/66.html’ //开头加入该代码

    dependences{

    implementation ‘org.greenrobot:green:3.2.0’

    }

    然后就可以使用了。

    bean实体

    可以在项目中创建自己业务需要的实体类,并通过注解来设置是实体类,字段约束等内容。然后点击Android Studio中的Make mole,即可自动生成XXXDao代码,以此来方便开发者的操作。生成的XXXDao类,不可修改和编辑,是自动生成的。

    ORMLite

    ORMLite框架是另外一款Android开发中可以使用的数据库操作框架。该框架的文档地址如下:https://ormlite.com/sqlite_java_android_orm.shtml

    该框架的文档准备的不是特别友好,此处不再赘述。

    总结,所有的框架原理几乎都相差不大,只是操作有所差异。

    视图注入框架

    在Android项目开发过程中,有太多的页面需要布局完成,同时在代码中需要些大量的findviewbyid的操作,来实现控件的解析。于是就有人想能否轻松一些,解放双手节省时间,干一些其他有意义的事情,于是ButterKnife就来了。

    ButterKnife是一个专注于Android系统的View注入框架,可以减少大量的findViewById以及setOnClickListener代码,可视化一键生成。

    该项目在github上的地址如下:http://www.xingkongmj.com/news/id/65.html

    这个框架的优势也非常明显:

    强大的View绑定和Click事件处理功能,简化代码,提升开发效率方便的处理Adapter里的ViewHolder绑定问题运行时不会影响APP效率,使用配置方便代码清晰,可读性强
    使用

    首先是设置依赖,在build.gradlehttp://dachang.net/432714.html中进行依赖设置:

    implementation ‘com.jakewharton:butterknife:10.2.1’

    annotationProcessor ‘com.jakewharton:butterknife-compiler:10.2.1’

    需要注意,该框架要求Java环境1.8版本以上,SDK版本在26以上,因此在使用到的mole中的build.graldle文件中,还必须添加如下代码配置:

    apply plugin: ‘com.jakewharton.butterknife’

    android{

    //…

    compileOptions {

    sourceCompatibility JavaVersion.VERSION_1_8

    targetCompatibility JavaVersion.VERSION_1_8

    }

    //…

    }

    另外,还必须在项目根目录中的build.gradle文件中,添加该框架的插件,如下图所示:

    dependences{

    classpath ‘com.jakewharton:butterknife-gradle-plugin:10.2.1’

    }

    然后即可在代码中进行使用了。

    在使用该框架的页面进行绑定诸如,如下所示代码:

    ButterKnife.bind( this) ;

    主要的功能

    @BindView():控件id 注解,解放双手,不用再每个控件都写一遍findviewById@BindViews():多个控件id 的注解,括号内使用花括号包括多个id即可,中间用,分割开在Fragment中使用,绑定Fragment。@BindString():绑定字符串@BindArray:绑定数组@BindBitmap:绑定bitmap资源@OnClick、@OnLongClick:绑定点击事件和长按事件…还有很多
    插件安装

    如果是页面很复杂,一个一个写BindView也很费劲,在Android Studio中,可以安装一个ButterKnife的插件,安装该插件后,可以在Studio中直接将对应的布局中的所有控件均给自动生成。

    注意,在进行自动生成时,鼠标要放在布局文件上。

    注意事项

    ButterKnife框架在使用时,要求的版本比较高,包括Java的版本也有限制。因此,如果计划在项目中使用,要提前做好预备工作,以防止对已有项目和业务带来不必要的麻烦,反而影响工作进度。

B. green怎么更改数据库版本号

项目开发中用到的就是GreenDAO数据库框架,需要进行数据库版本升级。
其实数据库版本升级比较麻烦的就是数据的迁移,data migration。
数据库版本升级有很多方法,按不同需求来处理。
本质上是去执行sql语句去创建临时数据表,然后迁移数据,修改临时表名等。
数据版本升级,为了便于维护代码可以先定义一个抽象类
public abstract class AbstractMigratorHelper {

public abstract void onUpgrade(SQLiteDatabase db);
}1234

然后让自己更新数据库逻辑的类继承这个类
public class DBMigrationHelper6 extends AbstractMigratorHelper {

/* Upgrade from DB schema 6 to schema 7 , version numbers are just examples*/

public void onUpgrade(SQLiteDatabase db) {

/* Create a temporal table where you will all the data from the previous table that you need to modify with a non supported sqlite operation */
db.execSQL("CREATE TABLE " + "'post2' (" + //
"'_id' INTEGER PRIMARY KEY ," + // 0: id
"'POST_ID' INTEGER UNIQUE ," + // 1: postId
"'USER_ID' INTEGER," + // 2: userId

C. android contentprovider 怎么操作green的数据库

有时我们需要对文件或数据库进行测试,但我们又不想破坏应用程序或设备原有的数据。此时我们就需要一个Mock来替代他们,这里的Mock不是android.test.mock,但也是android.test包下面的,RenamingDelegatingContext的类。示例参见:D:\workspace\MockTest*******************MockContextExampleActivity********packagecom.example.mocktest;importjava.io.FileInputStream;importandroid.app.Activity;importandroid.graphics.Color;importandroid.os.Bundle;importandroid.view.Menu;importandroid.widget.TextView;{publicfinalstaticStringFILE_NAME="myfile.txt";privateTextViewmTv;@OverrideprotectedvoidonCreate(BundlesavedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);mTv=(TextView)findViewById(R.id.text1);finalbyte[]buffer=newbyte[1024];try{finalFileInputStreamfis=openFileInput(FILE_NAME);finalintn=fis.read(buffer);mTv.setText(newString(buffer,0,n-1));}catch(Exceptione){mTv.setText(e.toString());mTv.setTextColor(Color.RED);}}//这里写了个getText方法,测试工程会用到。publicStringgetText(){returnmTv.getText().toString();}@(Menumenu){//Inflatethemenu;.getMenuInflater().inflate(R.menu.mock_context_example,menu);returntrue;}}*****************MockContextExampleTest*****************packagecom.example.mocktest;importandroid.content.Intent;importandroid.test.ActivityUnitTestCase;importandroid.test.RenamingDelegatingContext;{="test.";;publicMockContextExampleTest(){super(MockContextExampleActivity.class);}@OverrideprotectedvoidsetUp()throwsException{super.setUp();mMockContext=newRenamingDelegatingContext(getInstrumentation().getTargetContext(),PREFIX);mMockContext.();}@OverrideprotectedvoidtearDown()throwsException{super.tearDown();}(){setActivityContext(mMockContext);startActivity(newIntent(),null,null);=getActivity();assertNotNull(mActivity);Stringtext=mActivity.getText();assertEquals("Thisis*MOCK*data",text);}}Notice:别忘了在清单文件里加上RenamingDelegatingContext函数的使用,PREFIX是表示文件或数据库的前缀。另外这里为什么使用getTargetContext方法而不是getContext,后者我们经常在UiTest中使用到。这里其实看下注释就明白了://getContext():Theinstrumentation’spackagecontext.//getTargetContext():.运行下测试,pass。这说明getText方法返回的string已经是Thisis*MOCK*data而不是Thisisrealdata了。这就可以证明,开发没有写死这段话。以上就是RenamingDelegatingContext函数如何来mock文件的,数据库的使用也是一样的。

D. green用完需要手动关闭数据库吗

点开green某方法

privatevoiddeleteInTxInternal(Iterable<T>entities,Iterable<K>keys){
//此处打开
db.beginTransaction();
try{
...
}finally{
//此处关闭
db.endTransaction();
}
}

green不需要手动去打开和关闭数据库,已经帮我们做好了

E. GreenDao 有对数据库内容监听的功能么

你只能监控从JAVA端对数据库的操作(CURD),可统一在切面拦截时进行写日志的操作,如果要监控用户通过第三方软件连接到数据库的操作,你只能读取MYSQL日志进行分析了。

F. 在Android开发中用GreenDao操作SQLite数据库后,SQLite数据库用SQLite Expert Personal无法正常打开

});//alert($('#modifyCustomerForm').validate().form());return$('#modifyCustomerForm').validate().form();},url:"addCustomerAction.action",type:"POST",error:function(){showDialog("error");},success:function(data){$("#dialog").dialog("提示");$("#dialog").text("修改成功");$('#dialog').dialog({modal:true,buttons:{确定:function(){document.location="searchCustomerAction.action?page=1";}

G. 如何查看green3生成的数据库

如何查看green3生成的数据库
:使用 Guid 作为我一个服务器应用程序中的主键,并且想要能够远程从 android 设备和上载回服务器生成新的数据。Android 设备上的数据库是在 sqlite 中,并使用 greenDAO 来生成 Pojo 和数据访问层

H. GreenDAO的数据库操作需要在子线程完成吗

当然是可以的,在线程里面会有很多程序,可以调用任何程序啊,这样调用的程序都在一个线程里完成的。在这个过程中当然也可以调用database类来完成对数据库的操作。

I. green用的是什么数据库

GreenDao是一个用于Android开发的对象/关系映射(ORM)工具。它向SQLite数据库提供了一个对象导向的接口。greenDAO有如下特点:系能最大化、便于使用、对于Android高度优化、最小化内存开销、较小的文件体积,只集中在必要的部分上

J. GreenDao insertOrReplace和save的区别

你好,很高兴为你解答

关于GreenDao insertOrReplace和save的区别:

  • insertOrReplace : 传入的对象在数据库中,有则更新无则插入。推荐同步数据库时使用该方法。

  • save 类似于insertOrReplace,区别在于save会判断传入对象的key,有key的对象执行更新,无key的执行插入。当对象有key但并不在数据库时会执行失败.适用于保存本地列表。

适用场景

  1. 只有本地数据库,且key默认由数据库生成。直接使用save就好

  2. 插入的数据有key,其实这种情况通常是同步线上数据到本地数据库时的情况,因为直接使用了数据库的key,所以不能使用save,必须使用insertOrReplace。

结论

在确保插入数据有key时必须存在于数据库的情况下,适用save更高效。其他情况一律适用insertOrReplace

不足之处还望大神指正