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

以面向对象的方式看待sql

sql语句由好多部分组成。
把每一部分抽象出类。

Condition

翻译:条件

什么是条件?

举个例子:
有一张学生表,其中有个 age 字段,现在有这样的需求:查找出所有年龄大于18岁的学生。

sql: select from student where age>18;

where 后面的 age>18就是条件。

1.分拆元素

条件需要的几个元素:

DBFlow源码分析:SQL拆解(Condition)_第1张图片

DBFlow将这几个元素抽象为 SQLCondition:

DBFlow源码分析:SQL拆解(Condition)_第2张图片

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

2.对属性的操作

对列名这个属性,我们对他们会有很多操作:
age=18
age>18
age is null
...

在DBFlow中 IConditional来描述这些操作:


DBFlow源码分析:SQL拆解(Condition)_第3张图片

属性实现了这个接口:

DBFlow源码分析:SQL拆解(Condition)_第4张图片

具体的实现,借给了condition来处理

DBFlow源码分析:SQL拆解(Condition)_第5张图片

3. 结合

元素与 操作的结合:


DBFlow源码分析:SQL拆解(Condition)_第6张图片

4. 例子

针对name属性来构造一个条件:name="lijian"

DBFlow源码分析:SQL拆解(Condition)_第7张图片

针对属性的eq方法,它实际上调用了 Condition的eq方法。

属性Property中的操作方法是对condition的包装

DBFlow源码分析:SQL拆解(Condition)_第8张图片

列名,操作符,数值都准备好了,那么它是怎么生成sql语句的?

DBFlow源码分析:SQL拆解(Condition)_第9张图片

你可能感兴趣的:(DBFlow源码分析:SQL拆解(Condition))