@Param注解和@Pathvariable注解

关于@Param

第一种方式:

在Dao层中

Public User selectUser(@param(“userName”) String name, @param(“userpassword”) String password);

在xml映射文件中

<select id=" selectUser" resultMap="BaseResultMap">  
    select  *  from user 
        where user_name = #{userName,jdbcType=VARCHAR} and user_password=#{userPassword,jdbcType=VARCHAR}  
</select>

此时 @Param 的作用就相当于把 String name 的值引用到 括号内的参数中 username,而xml文件同时也通过 #{} 的方式进行注入参数。

这里在说一下 #{}${} 的区别

  • #{} 是占位符,让SQL完成预编译处理,防止 SQL 的注入,在预编译的时候 #{} 会被解析成 ?,并添加上'' 。即 #{} -> '?'
  • ${} 只是字符串的替换

关于@Pathvariable

这个注解的作用在于 RequestMapping URI 样式映射,通过 @Pathvariable 绑定它传过来的值到方法的参数上。

@Controller
//http://localhost:80808
public class ShowPage{
    @RequestMapping("/{page}")
    //http://localhost:80808/{page}
    public void showPage(@Pathvariable("page") String mypage){
        return mypage;
    }
}

上面代码中,mypage 的值通过 @Pathvarible 注解绑定到参数 page。而RequestMapping通过这个 page 参数来读取到 mypage 的值

如果RequestMapping 的参数和方法参数名称不一致,需要通过 @Pathvariable 来指定。如果一致可以省略

@Controller
//http://localhost:80808
public class ShowPage{
    @RequestMapping("/{page}")
    //http://localhost:80808/{page}
    public void showPage(@Pathvariable String page){
        return page;
    }
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值