當前位置:首頁 » 數據倉庫 » 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

不足之處還望大神指正