自己動手寫DB數(shù)據(jù)庫框架(性能優(yōu)化)

1. 概述


基于目前還是小白,那么寫過的代碼每次必會優(yōu)化逃延,我們就拿上次自己寫的數(shù)據(jù)庫框架優(yōu)化一下吧览妖。之所以自己寫一方面是因為內(nèi)涵段子項目的需求問題,必須按需定制揽祥;還有一方面我想寫得更好在性能方面一定要想方設(shè)法超過第三方的開源數(shù)據(jù)庫框架讽膏。

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

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

2. 開源性能對比


我從網(wǎng)上找了一個數(shù)據(jù)給大家看一下,分別是LitePal拄丰,AFinal府树,greenDAO。批量插入10000條數(shù)據(jù)愈案,三種框架用時為:

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

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

LitePal          997ms;
Darren           517ms;

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

3. 代碼部分

    // 參數(shù)的緩存
    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轉(zhuǎn)換成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);
                }
                // 反射執(zhí)行方法
                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. 使用方式


增刪改查啤它,使用起來還是蠻簡單的饲握,數(shù)據(jù)庫存放的位置在外部存儲卡中:

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

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

// 4.2 插入數(shù)據(jù)對象(批量)
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 根據(jù)條件進行查詢
List<Person> persons = daoSupport.querySupport()
    .selection("age = ?").selectionArgs("23").query();

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

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

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

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末私杜,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子救欧,更是在濱河造成了極大的恐慌衰粹,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件笆怠,死亡現(xiàn)場離奇詭異铝耻,居然都是意外死亡,警方通過查閱死者的電腦和手機蹬刷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門瓢捉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人办成,你說我怎么就攤上這事泡态。” “怎么了迂卢?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵某弦,是天一觀的道長。 經(jīng)常有香客問我而克,道長靶壮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任员萍,我火速辦了婚禮腾降,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘碎绎。我一直安慰自己螃壤,他們只是感情好,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布筋帖。 她就那樣靜靜地躺著奸晴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幕随。 梳的紋絲不亂的頭發(fā)上蚁滋,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天赘淮,我揣著相機與錄音,去河邊找鬼睦霎。 笑死梢卸,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的副女。 我是一名探鬼主播蛤高,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了戴陡?” 一聲冷哼從身側(cè)響起塞绿,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎恤批,沒想到半個月后异吻,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡喜庞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年诀浪,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片延都。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡雷猪,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晰房,到底是詐尸還是另有隱情求摇,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布嫉你,位于F島的核電站月帝,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏幽污。R本人自食惡果不足惜嚷辅,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望距误。 院中可真熱鬧簸搞,春花似錦、人聲如沸准潭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽刑然。三九已至寺擂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間泼掠,已是汗流浹背怔软。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留择镇,地道東北人挡逼。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像腻豌,于是被迫代替她去往敵國和親家坎。 傳聞我的和親對象是個殘疾皇子嘱能,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

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