自己動手寫DB數據庫框架(性能優化)

1. 概述


基于目前還是小白,那么寫過的代碼每次必會優化,我們就拿上次自己寫的數據庫框架優化一下吧。之所以自己寫一方面是因為內涵段子項目的需求問題,必須按需定制;還有一方面我想寫得更好在性能方面一定要想方設法超過第三方的開源數據庫框架。

所有分享大綱:2017Android進階之路與你同行

視頻講解地址:http://pan.baidu.com/s/1pLM1X3t

2. 開源性能對比


我從網上找了一個數據給大家看一下,分別是LitePal,AFinal,greenDAO。批量插入10000條數據,三種框架用時為:

LitePal          12882ms;
AFinal           2783ms;
greedDAO         623ms;

估計很多人觀察我很久了,早就看你不順眼了,老是盜取別人的數據。這個請見諒,我不是故意的,大家應該都還記得王自如和羅永浩的大戰,所以我就拿某個哥們的展示一下,非常感謝數據的提供。接下來我就拿我比較熟悉的LitePal和我自己的做一下對比,同樣10000條數據:

LitePal          997ms;
Darren           517ms;

以上的數據只是用來測試并不能代表什么,各位請自行忽略,請自帶馬賽克,之所以速度還行是因為按需定制,這個項目不需要寫那么麻煩,夠用就好,為什么只優化了插入部分呢?目前不能在數據庫停留太久,要加快步伐把內涵段子完結,后面有時間會做NDK數據庫加解密,懶加載等等、沒有最好只有更好。LitePal使用過的人都知道很好用,真的蠻不錯的用起來很方便,自己也看過作者郭大神很多的文章以及視頻,今天小弟黑了你實在不好意思哈哈。

3. 代碼部分

    // 參數的緩存
    private final Object[] mPutMethodArgs = new Object[2];
    // put反射方法的緩存
    private static final Map<Class<?>, Method> mInputMethods
            = new ArrayMap<>();

    // 批量插入
    @Override
    public void insert(List<T> list) {
        mSqLiteDatabase.beginTransaction();
        for (T t : list) {
            insert(t);
        }
        mSqLiteDatabase.setTransactionSuccessful();
        mSqLiteDatabase.endTransaction();
    }

    // 單條插入
    @Override
    public long insert(T obj) {
         ContentValues values = transformContentValue(obj);
         return mSqLiteDatabase.insert(DBUtils.getTableName(mClass), null, values);
    }

     /**
     * 把Object轉換成ContentValues
     *
     * @return ContentValues
     */
    private ContentValues transformContentValue(T obj) {
        ContentValues values = new ContentValues();
        Field[] fields = mClass.getDeclaredFields();
        for (Field field : fields) {
            try {
                field.setAccessible(true);
                // 通過反射獲取字段名和字段值
                String putName = field.getName();
                Object putValue = field.get(obj);
                if (putValue == null) {
                    continue;
                }

                // 感謝google提供的源碼,很快我們又會再見
                Class<?> putValueClass = putValue.getClass();
                Method putMethod = mPutMethods.get(putValueClass);
                // 從緩存里面獲取
                if (putMethod == null) {
                    putMethod = ContentValues.class.getMethod("put",
                            String.class, putValueClass);
                    mPutMethods.put(putValueClass, putMethod);
                }
                // 反射執行方法
                mPutMethodArgs[0] = putName;
                mPutMethodArgs[1] = putValue;
                putMethod.invoke(values, mPutMethodArgs);
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                // 置為空
                mPutMethodArgs[0] = null;
                mPutMethodArgs[1] = null;
            }
        }
        return values;
    }

4. 使用方式


增刪改查,使用起來還是蠻簡單的,數據庫存放的位置在外部存儲卡中:

// 4.0 直接從工廠里面獲取daoSupport 
IDaoSupport<Person> daoSupport = DaoSupportFactory.getFactory().
        getDaoSupport(Person.class);

// 4.1 插入數據對象(單條)
daoSupport.insert(new Person("Darren", 23));

// 4.2 插入數據對象(批量)
List<Person> persons = new ArrayList<>();
for (int i = 0; i < 10000; i++) {
    persons.add(new Person("darren", "23"));
}
daoSupport.insert(persons);

// 4.3 查詢所有
List<Person> persons = daoSupport.querySupport().queryAll();

// 4.4 根據條件進行查詢
List<Person> persons = daoSupport.querySupport()
    .selection("age = ?").selectionArgs("23").query();

// 4.5 根據條件進行刪除
daoSupport.delete("age = ?","23");

// 4.6 根據條件進行更新
Person person = new Person("Jack",24);
daoSupport.upadte(person,"age = ?","23");

所有分享大綱:2017Android進階之路與你同行

視頻講解地址:http://pan.baidu.com/s/1pLM1X3t

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,428評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,024評論 3 413
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,285評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,548評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,328評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,878評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,971評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,098評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,616評論 1 331
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,554評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,725評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,243評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,971評論 3 345
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,361評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,613評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,339評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,695評論 2 370

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,583評論 25 707
  • 這是一些學習資源,里面有Android的,iOS的,PHP的,大數據的,Java的,web前端的,C++,Pyth...
    草蜢的逆襲閱讀 5,232評論 1 50
  • 我知道自己未老,只是多了孤單。有時候,路走得太急,難免忽略耳畔的風景。一如當年不同城市或縣城里的短暫的奔波,那時真...
    天涯草閱讀 430評論 0 1
  • 辭職后的半個月底時間,閑來無事入手了一本柴靜的《看見》,看完下來花了半個月的時間,起初也是企圖把它拿來當做消磨時間...
    耿曉雨閱讀 359評論 0 0
  • -01- 年少的時候,愛一個人很單純。 愛他干凈纖長的手指,愛他俊朗的眉宇,深邃的眼神和打籃球時頎長矯健的身材,在...
    Nico尼可閱讀 4,429評論 26 79