DBFlow源碼分析:SQL拆解(Condition)

以面向?qū)ο蟮姆绞娇创齭ql

sql語句由好多部分組成就珠。
把每一部分抽象出類蛉威。

Condition

翻譯:條件

什么是條件仿荆?

舉個(gè)例子:
有一張學(xué)生表臊泌,其中有個(gè) age 字段鲤桥,現(xiàn)在有這樣的需求:查找出所有年齡大于18歲的學(xué)生。

sql: select from student where age>18;

where 后面的 age>18就是條件渠概。

1.分拆元素

條件需要的幾個(gè)元素:

DBFlow將這幾個(gè)元素抽象為 SQLCondition:

元素 SQLCondition
列名稱 columnName
操作符 operation
value

2.對屬性的操作

對列名這個(gè)屬性茶凳,我們對他們會有很多操作:
age=18
age>18
age is null
...

在DBFlow中 IConditional來描述這些操作:


屬性實(shí)現(xiàn)了這個(gè)接口:

具體的實(shí)現(xiàn),借給了condition來處理

3. 結(jié)合

元素與 操作的結(jié)合:


4. 例子

針對name屬性來構(gòu)造一個(gè)條件:name="lijian"

針對屬性的eq方法播揪,它實(shí)際上調(diào)用了 Condition的eq方法贮喧。

屬性Property中的操作方法是對condition的包裝

列名,操作符猪狈,數(shù)值都準(zhǔn)備好了箱沦,那么它是怎么生成sql語句的?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末雇庙,一起剝皮案震驚了整個(gè)濱河市谓形,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌疆前,老刑警劉巖寒跳,帶你破解...
    沈念sama閱讀 222,946評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異竹椒,居然都是意外死亡童太,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,336評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來书释,“玉大人翘贮,你說我怎么就攤上這事≌骼洌” “怎么了择膝?”我有些...
    開封第一講書人閱讀 169,716評論 0 364
  • 文/不壞的土叔 我叫張陵誓琼,是天一觀的道長检激。 經(jīng)常有香客問我,道長腹侣,這世上最難降的妖魔是什么叔收? 我笑而不...
    開封第一講書人閱讀 60,222評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮傲隶,結(jié)果婚禮上饺律,老公的妹妹穿的比我還像新娘。我一直安慰自己跺株,他們只是感情好复濒,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,223評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著乒省,像睡著了一般巧颈。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袖扛,一...
    開封第一講書人閱讀 52,807評論 1 314
  • 那天砸泛,我揣著相機(jī)與錄音,去河邊找鬼蛆封。 笑死唇礁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的惨篱。 我是一名探鬼主播盏筐,決...
    沈念sama閱讀 41,235評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼砸讳!你這毒婦竟也來了琢融?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,189評論 0 277
  • 序言:老撾萬榮一對情侶失蹤绣夺,失蹤者是張志新(化名)和其女友劉穎吏奸,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體陶耍,經(jīng)...
    沈念sama閱讀 46,712評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡奋蔚,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,775評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片泊碑。...
    茶點(diǎn)故事閱讀 40,926評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡坤按,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出馒过,到底是詐尸還是另有隱情臭脓,我是刑警寧澤,帶...
    沈念sama閱讀 36,580評論 5 351
  • 正文 年R本政府宣布腹忽,位于F島的核電站来累,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏窘奏。R本人自食惡果不足惜嘹锁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,259評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望着裹。 院中可真熱鬧领猾,春花似錦、人聲如沸骇扇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,750評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽少孝。三九已至继低,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間韭山,已是汗流浹背郁季。 一陣腳步聲響...
    開封第一講書人閱讀 33,867評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留钱磅,地道東北人梦裂。 一個(gè)月前我還...
    沈念sama閱讀 49,368評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像盖淡,于是被迫代替她去往敵國和親年柠。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,930評論 2 361

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

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法褪迟,類相關(guān)的語法冗恨,內(nèi)部類的語法,繼承相關(guān)的語法味赃,異常的語法掀抹,線程的語...
    子非魚_t_閱讀 31,668評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)心俗,斷路器傲武,智...
    卡卡羅2017閱讀 134,719評論 18 139
  • Spark SQL, DataFrames and Datasets Guide Overview SQL Dat...
    Joyyx閱讀 8,329評論 0 16
  • 今天得到app上李笑來老師給出的下周課題預(yù)告是:是什么決定了選擇蓉驹?我腦子里第一反應(yīng)就是四個(gè)字“從心所欲”。在兩年之...
    烏卓閱讀 390評論 1 0
  • 夢想許是幼稚揪利, 理想應(yīng)是新奇态兴。 著迷又如何, 還不是得離去疟位。 痛苦又如何瞻润, 誰又能擁有萬年的光景。 天上...
    古風(fēng)長歌閱讀 262評論 1 3