关于Mybatis参数的命名规则

   1.如果是单个参数传递,那么sql语句中“#{}”括号里的名字可以随便写。

      2.如果是多个参数传递,Mybatis会做特殊处理

A) 多个参数会被封装成一个Map,其中keyparam1...paramN(或者是0,1,2.....)value就是传入的参数值,#{}其实就是从Map中获得指定的key的值。

B) 如果随便传入参数名Mybatis会报BingdingExcption错误,提示参数名找不到。

C) 我们可以通过命名参数的方式来传入我们所指定的参数名:

      例如在一个Mapper接口中有:

   public Employee getEmpByIdAndName(Integer id,String name); 

      这样一个方法,就可以通过@Param注解来给我们的参数指定别名,就像这样:        

   public Employee getEmpByIdAndName(@Param(“id”)Integer id,@Param(“name”)String name);

D) 如果参数正好是我们业务中的数据模型,我们可以直接传入pojo(普通的JavaBean):

       #{属性名}:取出传入的pojo的属性值。

E) 如果多个参数不是业务中的数据模型,没有对应的pojo,为了方便,我们也可以传入自定义的Map,把我们想要传递的参数名封装在这个Map,还是上面的例子:    

    public Employee getEmpByIdAndName(Map<String,Object> map);

 这样在调用Mapper时就可以通过以下方法来指定Map的封装:    

     EmployeeMapper mapper=opensession.getMapper(EmployeeMapper.Class)
  
     Map<String,Object> map=new HashMap<>();

     map.put(“id”,2);

     map.put(“name”,”tom”);

     Employee emp=mapper.getEmpByIdAndName(map); 

 这样就相当于给sql传入了自定义的#{id}#{name}的值了。

F) 如果多个参数不是业务模型的数据模型,但方便起见,要经常使用,来编写一个To(Transfer Object)数据传输对象,将我们的数据模型放在Page{}里面。

3.#{}和${}的区别:

#{}:是以预编译格式,将参数设置到sql语句中,相当于PreparedStatement,可以防止sql注入;

${}:会将取出的值拼接在sql语句中,相当于Statement,会有安全问题;

大多数情况下,我们都是用#{}来进行取值,jdbc不支持占位符的地方使用${}进行取值,比如分表,或者oder by ${} ${升序还是降序}等。

posted @ 2019-04-21 16:25  人迹罕至的那条路  阅读(2277)  评论(0编辑  收藏  举报