• mybatis中关于${}和#{}取值的区别


    1.相同点:

      #{}:都可以获取map中的值或者pojo对象属性的值;
      ${}:都可以获取map中的值或者pojo对象属性的值;

    区别:  

      #{}:是以预编译的形式,将参数设置到sql语句中(?,?,?)的形式,相当于原生JDBC中的PreparedStatement,可以防止sql注入;

      ${}:取出的值直接拼接在sql语句中,会有安全问题

    建议: 大多数情况下,我们去参数的值都应该去使用#{};

    ${}的使用:

      原生jdbc不支持占位符的地方我们就可以使用${}进行取值
            比如分表、排序。。。;按照年份分表拆分
                select * from ${year}_salary where xxx;
                select * from tbl_employee order by ${f_name} ${order}

    #{}:更丰富的用法:
        规定参数的一些规则:
        javaType、 jdbcType、 mode(存储过程)、 numericScale、
        resultMap、 typeHandler、 jdbcTypeName、 expression(未来准备支持的功能);

        jdbcType通常需要在某种特定的条件下被设置:
            在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。比如Oracle(报错);
            (在我们向数据库插入一条数据时,有些字段为空时,在mysql下可以正常插入,不考虑数据库的约束情况,在oracle下插入时有会爆jdbc Type OTHER的错误,因为mybaits

    默认情况下是jdbc Type OTHER类型的,oracle不支持该类型),所以只要在下列加上一句oracle支持的类型jdbcType=null就可以成功的插入到oracle数据中


            JdbcType OTHER:无效的类型;因为mybatis对所有的null都映射的是原生Jdbc的OTHER类型,oracle不能正确处理;
            
            由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持;两种办法
            1、#{email,jdbcType=OTHER};
            2、jdbcTypeForNull=NULL
                <setting name="jdbcTypeForNull" value="NULL"/>

  • 相关阅读:
    Xamarin.Forms项目无法添加服务引用
    Xamarin Android长度单位区别
    21IC菜农研究的HotWC3超级CRC运算器
    Delphi天气预报查询
    超外差接收机工作原理?
    ARM汇编指令的特点和速查表
    序列号的设计,不重复的实现一机一码
    iOS第一个简单APP
    GetEnvironmentVariable 获取常用系统变量(转)
    Delphi版的Base64转换函数(修改版)
  • 原文地址:https://www.cnblogs.com/gepuginy/p/10645264.html
Copyright © 2020-2023  润新知