• mybatis参数传参、取值处理等


    1. 单个参数:mybatis不会做特殊处理

      1. 取值方式:#{参数名} 这里参数名不必与方法的形参名称一致,可以用任意参数名来接受实参
      2. 例子:方法:update(Integer id) sql映射文件取值#{a},这样也可以取到值
    2. 多个参数:mybatis会做特殊处理,即把多个参数封装成一个map ,key:param1....paramN,value:传入的参数值,#{}就是就是从map中获取指定的key的value,即#{param1},#{param2}等

    3. 多个参数处理:自定义封装参数的key

      1. 方法 get(@Param("id") Integer id,@Param("name") String name) key使用@Param注解指定的值
      2. 取值:#{id},#{name} #{自定的key}取出对应的值
    4. 如果多个参数正好是我们业务逻辑的数据模型(可以只是模型的部分数据)就可以直接传入pojo

      1. #{属性名}取出传入的pojo属性值
    5. 如果多个参数不是我们我们业务逻辑的模型,没有对应的pojo,不推荐为了方便,我们可以传入map

      1. #{key}取出map中对应的值
    6. 如果多个参数不是我们我们业务逻辑的模型,但是经常使用,推荐封装成一个vo(其实就是一个简单的javabean,把所有参数封装到一个java类中)

    7. 如果形参只有一个,但是形参的类型是集合(collection,list,set)或者数组,也会做特殊处理,把它们封装到map中

      1. 如果形参是collection,那么map的key是collection
      2. 如果是collection中的list,那么map的key是list,取值#{list[0]},表示取出list中第一个元素
      3. 如果是数组,那么map的key是array,取值#{array}
    8. #{}取值和${}取值的区别

      1. #{}是以预编译的形式,将参数设置到sql中 ,利用preparedStatement,防止sql注入
      2. ${},取出的值直接拼在sql中,有安全问题
      3. 原生jdbc不支持占位符的地方zhi能用${}取值,比如分表、排序等
    9. #{}更丰富的用法

      1. 规定参数的一下规则:javaType、 jdbcType、 mode(存储过程)、 numericScale、
        resultMap、 typeHandler、 jdbcTypeName、 expression(未来准备支持的功能)

      2. jdbcType:数据库类型:通常需要在某种特定的条件下被设置:

        1. 在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。比如Oracle(报错);

        2. JdbcType OTHER:无效的类型;因为mybatis对所有的null都映射的是原生Jdbc的OTHER类型,oracle不能正确处理;

        3. 由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持;两种办法

          1. #{email,jdbcType=OTHER};

          2. jdbcTypeForNull=NULL

            <setting name="jdbcTypeForNull" value="NULL"/>
            
  • 相关阅读:
    WPF 策略模式
    老陈 WPF
    老陈 ASP.NET封装
    小石头 封装
    典型用户故事
    整数的四则运算
    对git的认识
    如何学习计算机
    团队编程二——web应用之人事管理系统
    团队编程——web应用之人事管理系统
  • 原文地址:https://www.cnblogs.com/syncmr/p/10955403.html
Copyright © 2020-2023  润新知