1.单个参数:mybatis不会特殊处理
#{参数名}:取出参数值
2.多个参数:mybatis会做特殊处理
多个参数会被封装成一个map,
key,param1...paramN,或者参数的索引也可以
#{ }就是从map中获取指定的key值
操作:
方法: public Employee getEmpByIdAndLastName(Integer id,String LastName);
取值:#{param1},#{param2}
data:image/s3,"s3://crabby-images/46de6/46de62acb97e6d5ef2b31b2aa3960ad7a6d62fb9" alt=""
data:image/s3,"s3://crabby-images/5827e/5827e3d0f733122ceda4adb514c91e83a7632db5" alt=""
data:image/s3,"s3://crabby-images/c02bf/c02bfaa086f744d062e555de9fab64f2c490d08c" alt=""
data:image/s3,"s3://crabby-images/d4c60/d4c60860b88f155bb36be12c7c0965211c275b9a" alt=""
3.命名参数:明确指定封装参数的map的key和@param("id")
多个参数会封装成一个map
key:使用@Param注解指定值
value:参数值
#{指定的key}取出对应的参数值
data:image/s3,"s3://crabby-images/ec2fd/ec2fde3435fde60b71b44e2c3189d64f1a8a1734" alt=""
data:image/s3,"s3://crabby-images/55918/55918e5e1fdeeb85cb732df5e41c9c1298107977" alt=""
4.POJO:
如果多个参加正好是我们业务逻辑数据模型,我们就可以直接传入pojo
#{属性名}:取出传入的pojo的属性值
5.Map:
如果多个参数不是业务模型中的数据,但是经常要使用。
data:image/s3,"s3://crabby-images/85add/85add4272078bbed9e979de1747fdcf3c5bf4c64" alt=""
data:image/s3,"s3://crabby-images/7e427/7e42773424d122e99af9d75697be8d4fcaaf7cb6" alt=""
6.TO:
如果多个参数不是业务模型中的数据,但是经常要使用,推荐来编写一个TO(Transfer Object)数据传输对象
Page{
int index;
int size;
}
网友评论