最好用的安卓數(shù)據(jù)庫DBFlow的使用方法

什么是DBFlow窘问?

Raizlabs公司開發(fā)的ORM(Object-relational mapping)庫。

DBFlow是一種使用注解(@~)來進(jìn)行表單的定義等數(shù)據(jù)庫處理话侄,并將這些處理簡(jiǎn)化的安卓數(shù)據(jù)庫框架。

DBFlow最出名的就是它的處理速度

※Raizlabs公司發(fā)布的処理速度比較結(jié)果

Results
complextrial.png
complextrialv1.png
simpletrial.png
simpletrialv1.png

DBFlow的導(dǎo)入

導(dǎo)入方法、使用方法官方文檔

DBFlow的導(dǎo)入需要做以下修改

  • build.gradle(Project)
    dependencies內(nèi)添加以下內(nèi)容杨赤。
dependencies {
    classpath 'com.neenbedankt.gradle.plugins:android-apt:1.7'
}
  • build.gradle(app)
dependencies {
    apt 'com.raizlabs.android:DBFlow-Compiler:2.2.1'
    compile "com.raizlabs.android:DBFlow-Core:2.2.1"
    compile "com.raizlabs.android:DBFlow:2.2.1"
}

DBFlow的使用方法

使用DBFlow需要追加2~3個(gè)新類敞斋。

  1. DBFlow初期化類(MyAppilcation.java)
  2. 數(shù)據(jù)庫宣言類(AppDatabase.java)
  3. 表格宣言類(User.java)

DBFlow初期化

FlowManager.init(this)初期化。

public class MyApplication extends Application {

    @Override
    public void onCreate() {
        super.onCreate();
        FlowManager.init(this);
    }
}

不要忘記AndroidManifest.xml里application標(biāo)簽的追加疾牲。


 <application
        android:name=".MyApplication" />
 </application>


數(shù)據(jù)庫的定義

@Database(name = AppDatabase.NAME, version = AppDatabase.VERSION)
public class AppDatabase {

    public static final String NAME = "AppDatabase";

    public static final int VERSION = 1;

}

表格的定義

注解

屬性(列)@Column植捎、主鍵(Primary Key)@PrimaryKey

@Table(databaseName = AppDatabase.NAME, tableName = "USER_TABLE")
public class User extends BaseModel { 

    @Column
    @PrimaryKey(autoincrement = true)
    int id;

    @Column(name = "NAME")
    public String name;

    @Column(name = "AGE")
    public int age;

}

查詢語句的書寫

  • Insert文
        User user = new User();
        user.name = "takenoki";
        user.age = 20;
        user.insert();
  • Select文
select NAME from USER_TABLE where NAME = "takenoki";

上面的SQL文在DBFlow里用使用以下語句。

     List<User> list = new Select()
                .from(User.class)
                .where(Condition.column(User$Table.NAME).is(name))
                .queryList();

想取名和年齡都一致的數(shù)據(jù)的話

     List<User> list = new Select()
                .from(User.class)
                .where(
                    Condition.column(User$Table.NAME).is(name),
                    Condition.column(User$Table.AGE).is(age)
                 )
                .queryList();

結(jié)果放在listView里表示的時(shí)候

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_sample, container, false);

        String name = "takenoki";
        int age = 20;

        ArrayAdapter<String> adapter = new ArrayAdapter<String>(
                act,
                android.R.layout.simple_list_item_1
        );

        List<User> list = new Select()
                .from(User.class)
                .where(Condition.column(User$Table.USER_NAME).is(name))
                .queryList();

        for (int i = 0; i < list.size(); i++) {
            adapter.add(String.valueOf(list.get(i).age));
        }

        listView.setAdapter(adapter);

        return view;
    }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末说敏,一起剝皮案震驚了整個(gè)濱河市鸥跟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌盔沫,老刑警劉巖医咨,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異架诞,居然都是意外死亡拟淮,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門谴忧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來很泊,“玉大人,你說我怎么就攤上這事沾谓∥欤” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵均驶,是天一觀的道長昏兆。 經(jīng)常有香客問我,道長妇穴,這世上最難降的妖魔是什么爬虱? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮腾它,結(jié)果婚禮上跑筝,老公的妹妹穿的比我還像新娘。我一直安慰自己瞒滴,他們只是感情好曲梗,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著妓忍,像睡著了一般虏两。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上单默,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天碘举,我揣著相機(jī)與錄音,去河邊找鬼搁廓。 笑死引颈,一個(gè)胖子當(dāng)著我的面吹牛耕皮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蝙场,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼凌停,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了售滤?” 一聲冷哼從身側(cè)響起罚拟,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎完箩,沒想到半個(gè)月后赐俗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡弊知,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年阻逮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秩彤。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叔扼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漫雷,到底是詐尸還是另有隱情瓜富,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布降盹,位于F島的核電站与柑,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏澎现。R本人自食惡果不足惜仅胞,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一每辟、第九天 我趴在偏房一處隱蔽的房頂上張望剑辫。 院中可真熱鬧,春花似錦渠欺、人聲如沸妹蔽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胳岂。三九已至,卻和暖如春舔稀,著一層夾襖步出監(jiān)牢的瞬間乳丰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工内贮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留产园,地道東北人汞斧。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像什燕,于是被迫代替她去往敵國和親粘勒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

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