@insert mybatis踩坑实体接收前端传递的参数
插入方法使用的使用entity实体对象进行接收的
@Insert(" insert into infor (name,pass,salary) values (#{infor.name},#{infor.pass},#{infor.salary})") public int save(@Param("infor") Infor infor);
//必须添加@param这个注解,使得mybatis去解析这个数据,否则一直提示infor的没有getter方法
@Insert(" insert into infor (name,pass,salary) values (#{name},#{pass},#{salary})") public int save( Infor infor);
经过后来的工作才 认识到,使用上面的一种方式确实可行,同时我们可以直接使用这个实体类的属性进行对应的insert的操作,特此来更新博文。
错误提示:
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'infor' in 'class com.ys.study.entity.Infor'
at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:419) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:164) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:162) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:49) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.MetaObject.getValue(MetaObject.java:122) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.MetaObject.metaObjectForProperty(MetaObject.java:145) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.reflection.MetaObject.getValue(MetaObject.java:115) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.scripting.defaults.DefaultParameterHandler.setParameters(DefaultParameterHandler.java:79) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.statement.PreparedStatementHandler.parameterize(PreparedStatementHandler.java:93) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.statement.RoutingStatementHandler.parameterize(RoutingStatementHandler.java:64) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.SimpleExecutor.prepareStatement(SimpleExecutor.java:86) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:49) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:117) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:76) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:198) ~[mybatis-3.4.6.jar:3.4.6]
at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:185) ~[mybatis-3.4.6.jar:3.4.6]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_171]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_171]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_171]
at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_171]
mybatis获取主键及参数传递的有关问题
获取主键值
insert into emp values(null,#{ename},#{age},#{sex}) /*insert into emp values(null,'${ename}',${age},'${sex}')*/
不同的参数类型,${}和#{}的不同取值方式
1.当传输参数为单个String或基本数据类型及其包装类
#{}
:可以以任意的名字获取参数值:
只能以{value}huo${_parameter}获取
2.当传输参数为javabean时
#{}和都可以通过属性名直接获取属性值,但是要注意{}的单引号问题
3.当传输多个参数时,mybatis会默认将这些参数放在map集合中
两种方式:
(1) 键为01.2,3,…n-1 以参数为值
(2) 键为param1,param2,param3…param(n).以参数为值
#{}
:#{arg0}/#{arg1};#{param1},#{param2}:
{param1},param2,{arg0},arg1.但是要注意{}的单引号问题
4.当传输map参数时
#{}和都可以通过键的名字直接获值,但是要注意{}的单引号问题
5.命名参数
可以通过@param(:‘key’)为map集合指定键的名字
Emp getEmpByIDAndEnameParam(@Param(“eid”) Integer eid, @Param(“ename”) String ename);
#{}和都可以通过键的名字直接获值,但要注意{}的单引号问题
6.当传输参数为List或Array,mybatis会将List或Array放在map中
List以list为键,Array以array为键
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。