DBFlow源码分析:SQL拆解(Condition)
2016-11-29 本文已影响64人
linheimx
以面向对象的方式看待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语句的?