MYBATIS04_@Param参数#{}和${}返回参数resultMap主键回写两种方式

Posted 所得皆惊喜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYBATIS04_@Param参数#{}和${}返回参数resultMap主键回写两种方式相关的知识,希望对你有一定的参考价值。

文章目录

①. @Param参数详解

  • ①. @Param的作用就是给参数命名,比如在mapper里面某方法A(int id),当添加注解后A(@Param(“userId”) int id),也就是说外部想要取出传入的id值,只需要取它的参数名userId就可以了。将参数值传如SQL语句中,通过#userId进行取值给SQL的参数赋值

  • ②. 实例一:@Param注解基本类型的参数
    其中where user_name = #userName and user_password = #password中的userName和password都是从注解@Param()里面取出来的,取出来的值就是方法中形式参数 String name 和 String pwd的值

//mapper中的方法:
public User selectUser(@Param("userName") String name,@Param("password") String pwd);
<!--映射到xml中的<select>标签-->
<select id="selectUser" resultMap="User">  
   select * from user  where user_name = #userName and user_password=#password  
</select>
  • ③. @Param注解JavaBean对象
    SQL语句通过@Param注解中的别名把对象中的属性取出来然后复制
//mapper中的方法:
public List<User> getAllUser(@Param("user") User u);
<!--映射到xml中的<select>标签-->
<select id="getAllUser" parameterType="com.vo.User" resultMap="userMapper">  
    select   
    from user t where 1=1  
         and   t.user_name = #user.userName  
         and   t.user_age = #user.userAge  
</select> 
  • ④. 不使用@Param注解时,参数只能有一个,并且是Javabean。在SQL语句里可以引用JavaBean的属性,而且只能引用JavaBean的属性
Integer insertUser(User user);
<insert id="insertUser" parameterType="user">
    insert into user(id,username) value(#id,#userName)
</insert>
  • ⑤. 当方法的参数有多个的时候,一定要用@Param标注

②. $和#的区别

  • ①. #:通过预编译的方式,推荐使用
  1. #表示一个占位符号,#接收输入参数,类型可以是简单类型,pojo等
  2. 如果接受简单类型,#里面的可以写成value或其他的
  3. # 接受的是pojo。要通过user.username的形式获取
# 如:需要执行如下的SQL,#是预编译处理,是占位符
select * from user where name = #userName;设userName=TANG
# 看日志我们可以看到解析时将#userName替换成了?
select * from user where name = ?;
# 然后再把TANG放进去,外面加上单引号

  • ②. $:表示一个拼接符号,会引起sql注入,所以不建议使用
  1. $接受输入参数,类型可以是简单类型,pojo等
  2. $接受的是pojo。要通过user.username的形式获取
# 如:需要执行如下的SQL,$是字符串替换,是拼接符
select * from user where name = #userName;设userName=yuze
# 看日志可以发现就是直接把值拼接上去了
select * from user where name = yuze;
# 这极有可能发生sql注入,下面举了一个简单的sql注入案例
  • ③. 注意:如果使用$,需要加上@Param注解,否则会报错

③. resultType、resultMap

  • ①. 通过resultType设置操作的返回结果类型,如果返回的是基本数据类型,那么我们可以直接写Java中的基本数据类型即可。如果返回的是一个对象或者集合,并且对象中的属性和查询的字段名一一对应,那么resultType可以直接写一个对象

  • ②. resultMap主要用来解决属性名和字段名不一致以及一对多、一对一查询等问题。字段名不一致时,首先可以通过取别名的方式解决、还可以通过resultMap映射的形式

④. 主键回写两种方式

  • ①. 主键自增主键回写
  1. useGeneratedKeys:使用生成的主键
  2. keyProperty:将生成的主键的值保存到对象的id属性中
<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
    insert into user(id,username) value(#id,#userName)
</insert>

  • ②. 自定义主键(一般使用UUID)
    可以利用mysql自带的last_insert_id() 函数来获取刚刚插入的id
    <insert id="add" parameterType="com.xiaozhi.pojo.CheckGroup">
        /*
        通过mybatis框架提供的selectKey来获得自增产生的id值
        order:insert 与 selectKey的执行顺序(BEFORE|AFTER)
        keyProperty:这个属性不能乱写,要对应CheckGroup实体类中的id
        */
       <selectKey resultType="int" order="AFTER" keyProperty="id">
           select LAST_INSERT_ID()
       </selectKey>
        insert into t_checkgroup(code,name,helpCode,sex,remark,attention)
        values
        (#code,#name,#helpCode,#sex,#remark,#attention)
    </insert>
创作打卡挑战赛 赢取流量/现金/CSDN周边激励大奖

以上是关于MYBATIS04_@Param参数#{}和${}返回参数resultMap主键回写两种方式的主要内容,如果未能解决你的问题,请参考以下文章

关于mybatis的@Param注解和参数

2019-04-04 Mybatis学习知识点

mybatis多个参数不加@Param

mybatis中@Param的用法和作用

[mybatis]映射文件_参数处理

mybatis 怎么获取多个参数