在 Structs 流行的时代 OGNL 可是必会的数据渲染技术。它全称 Object Graph Navigation Language,作用是降低对数据层访问的难度,它拥有类型转换、访问对象方法、操作集合对象等功能。目前已经很少通过 OGNL 来访问数据层了,目前国内大部分的 ORM 框架是 Mybatis,而 Mybatis 中的动态 SQL 技术运用了 OGNL。
Mybatis 中的 OGNL
不少人在 Mybatis 的 Mapper 文件中写过这样的判断:
1 | <if test="field!='' and field!= null"> |
当 field 不为空字符并且不为 null 的情况下增加一个查询条件。其中 test 就是一个 OGNL 表达式。Mybatis 中的 OGNL 表达式主要有两种用途。
条件断言
这种是最常用的。执行动态 SQL 的条件断言,常用的有这些表达式:
b1 or b2
条件 或b1 and b2
条件 与!b1
取反,也可以写作 not b1b1 == b2,b1 eq b2
判断两个值相等b1 != b2,b1 neq b2
判断两个值不想等b1 lt b2
判断 b1 小于(less than)b2b1 gt b2
判断 b1 小于(greater than)b2b1 lte b2
:判断 b1 小于等于 b2b1 gte b2
:判断 b1 大于等于 b2b1 in b2
判断 b2 包含 b1b1 not in b2
判断 b2 不包含 b1
这些表达式经常和 test 配合。
四则运算赋值
还有一些表达式用来赋值或者增强属性。经常用来做模糊搜索的 bind
标签:
1 | <bind name="nameLike" value="'%'+ name + '%'"/> |
这里的value
也属于 OGNL 表达式 e1+e2
,字符串是拼接,数字的话就是加法运算,可以引申出肯定还有:
e1*e2
乘法e1/e2
除法e1-e2
减法e1%e2
取模
类的内置方法
其实 Mybatis 的 Mapper.xml 中还可以使用对象的内置方法,比如需要判断一个java.util.Collection
集合是否为空,可以这么写:
1 | <if test="collection!=null and collection.size()> 0"> |
这里就使用了对象的内置方法Collection.size()
。
还可以调用自定义对象CollectionUtils
的静态方法来判断集合是否为空:
1 | public final class CollectionUtils { |
那么上面的<if>
判断改为:
1 | <if test="@cn.fcant.util.CollectionUtils@isNotEmpty(collection)"> |
这里要带上类的全限定名。
取值操作
取值操作的话,如果是对象直接e.property
,如果是集合或者Map
可以e[index|key]
,通过索引或者键名来取值。分别举个例子:
1 | # 对象取属性 |
其实静态属性也能取值调用,跟上面的静态方法类似:
1 | .fcant.Cache |
对应 Java 代码:
1 | public final class Cache { |
赋值操作
上面的取值除了可以做判断还可以用来 SQL 参数赋值:
1 | <where> |
通过${}
符号可以用 OGNL 表达式给 SQL 参数赋值。