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

96
linheimx
2016.11.29 17:49* 字数 292

以面向对象的方式看待sql

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

Condition

翻译:条件

什么是条件?

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

sql: select from student where age>18;

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

1.分拆元素

条件需要的几个元素:

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

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

2.对属性的操作

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

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


属性实现了这个接口:

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

3. 结合

元素与 操作的结合:


4. 例子

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

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

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

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

DBFlow
Web note ad 1