mybatis的@Param注解在Controller层的也可以传递参数

今天又解决了一个bug。

可能单纯就是乱码导致的。但是其中遇到几个问题。

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'userName' not found. Available parameters are [userName, param1] org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:76) org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:421) com.sun.proxy.$Proxy17.selectOne(Unknown Source) org.mybatis.spring.SqlSessionTemplate.selectOne(SqlSessionTemplate.java:166) org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:69) org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)

............

解决办法:

Mapper.java中原来是:

    public void delete(String specName);

修改为:

    public void delete(@Param("specName") String specName);

@Param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,正确的将参数传入sql语句中 

public Student select(@Param("aaaa") String name,@Param("bbbb")int class_id); 
给入参 String name 命名为aaaa,然后sql语句....where  s_name= #{aaaa} 中就可以根据aaaa得到参数值了


Controller的代码

    @RequiresRoles("admin")
    @RequestMapping("delete")
    public String delete(Model model,HttpServletRequest request) throws UnsupportedEncodingException{
    String specName=request.getParameter("specName");
    byte[] bs=specName.getBytes("ISO8859-1");
    specName=new String(bs,"UTF-8");
    model.addAttribute("sepcName",specName);
        specBiz.delete(specName);
        return "redirect:/spec.do/spec.view";
    }




然后有个问题就是数据库的数据,因为id是自增的,删除数据后,中间的就被删除,再次添加是直接往后顺着自增,前面就有空出的索引值

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值