ognl表达式

数据类型                                      标签中的属性
String以及基本类型              _parameter(就是_parameter)
自定义类型(如Student)  属性名(如studentname)
数组                                              array
List                list
Map                 _parameter


从集合中取数据


数组                String[index]
         Student[index].studentname
         
List     List<String>
         List<Message>.messagename
 
Map      _parameter.key 直接参数名.key
         key.studnetname  当为Map<String,Message>


利用<foreach>来循环数组和集合
<foreach collection="array" index="i" item="item">
当是数组和List的时候 i表示索引也就是下标 item即是值
当是Map的时候,i表示key值 item.属性名


ognl操作符 支持java的常用操作符如 + - * / == != 

自己特有的操作符 and or mod in(如果在集合中则返回true) not in(当不在集合中的时候返回true)


ex: <delete id="deleteone" parameterType="int">
  DELETE from message where ID=#{_parameter}
 </delete>

ex: <delete id="deletebatch" parameterType="java.util.List" >
   
     delete from message where ID in(
   <foreach collection="list" item="item" separator=",">
   #{item}
  </foreach>
  )
 
</delete>

       

<insert id="addnews"  parameterType="com.tx.bean.Message">  
        
        insert into message(ID,COMMAND,DESCRIPTION,CONTENT)   
        values        
        
    (#{id},#{command},#{description},#{content})  
        
    </insert>   



         
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OGNL(Object-Graph Navigation Language,对象图导航语言)是一个强大的表达式语言,可以用于Java的各种应用程序,包括Struts、JavaServer Faces、JavaServer Pages等。在MybatisOGNL表达式可以用于Mapper XML文件的各种标签,例如`<if>`、`<where>`、`<set>`、`<foreach>`等标签OGNL表达式可以用于获取Java对象的属性值、调用Java对象的方法、进行算术运算、比较运算、逻辑运算等。例如: ```xml <select id="selectByCondition" resultType="com.example.User"> select * from user where name like #{keyword} and age >= #{minAge} <if test="maxAge != null"> and age <= #{maxAge} </if> </select> ``` 在这个例子,`#{keyword}`、`#{minAge}`、`#{maxAge}`都是OGNL表达式,表示获取Java对象的属性值。例如,如果传入的参数对象是一个`User`对象,那么`#{keyword}`可以表示`user.getKeyword()`方法的返回值,`#{minAge}`可以表示`user.getMinAge()`方法的返回值。 在OGNL表达式,还可以进行算术运算、比较运算、逻辑运算等。例如,`age >= #{minAge}`表示将`age`和`#{minAge}`进行比较,判断`age`是否大于等于`#{minAge}`;`age <= #{maxAge}`表示将`age`和`#{maxAge}`进行比较,判断`age`是否小于等于`#{maxAge}`。 除了基本的运算符和表达式OGNL还提供了丰富的函数和操作符,例如`in`操作符、`not`操作符、`contains`函数、`size`函数等。这些函数和操作符可以方便地进行集合操作、字符串操作等。在使用OGNL表达式时,需要注意语法的正确性和安全性,以避免可能的安全漏洞。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值