今天又解决了一个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是自增的,删除数据后,中间的就被删除,再次添加是直接往后顺着自增,前面就有空出的索引值