zoukankan      html  css  js  c++  java
  • MyBatis学习(五)--Ognl表达式

    概念

      OGNL是Object-Graph Navigation Language的缩写,它是一种功能强大的表达式语言,通过它简单一致的表达式语法,可以存取对象的任意属性,调用对象的方法,遍历整个对象的结构图,实现字段类型转化等功能。它使用相同的表达式去存取对象的属性。这样可以更好的取得数据。

    用法

      Ognl表达式的用法与EL表达式的用法类似,作者这里就以它们作为对比进行简述:

      EL表达式:

        是JSP中所使用的表达式;写法:${属性名};

        对变量的处理,采用的是字符串拼接的方式;

        如:select * from author where id=${value}

      

        读取基本数据类型的值时,{}中只能写 value,不能填写其他值;

      Ognl表达式:

        是一种功能功能强大的表达式,可以存取对象的任意属性;写法:#{属性名};

        对变量的处理,采用的是预编译的方式;

        如:select * from author where id=#{id}

      

        读取基本数据类型的值时,{}中可以使任意变量名;

      作者这里将它们的区别简要做了一张表格,如下:

     

    EL表达式

    Ognl表达式

    变量的处理

    字符串拼接

    预编译

    基本数据类型

    ${value}

    #{任意变量名}

    对象类型(pojo类型)

    ${属性名}

    #{属性名}

     

    ${对象属性.属性}

    #{对象属性.属性}

      这里再通过一个案例来看看他们的区别:

      

      

      需要注意的是:

        EL表达式:字符串拼接,接收到的内容不加任何修饰直接拼接在SQL中,可能引起SQL注入;

        Ognl表达式:预编译,读取表达式的值,通过preparedStatement的方式进行SQL语句的执行;

    PS:因作者能力有限,如有误还请谅解

  • 相关阅读:
    Android获取View对应的Bitmap
    Android按需添加Google Play服务
    Android自定义View的构造函数
    两个Fragment之间如何传递数据
    SmartImageView
    onSingleTapUp()和onSingleTapConfirmed()的区别
    Android Fragment add/replace以及backstack
    InputStream与InputStreamReader的区别
    Android手动签名
    使用后台服务数据更新UI
  • 原文地址:https://www.cnblogs.com/WHL5/p/8686429.html
Copyright © 2011-2022 走看看