mybatis错误:Invalid bound statement (not found)

这又是一个前几天因为疏忽发生的问题。一般是Mapepr.xml文件中文nameapce没有和mapper接口发生映射,导致mybatis绑定失败。

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.xcdm.adminBag.mapper.ParentbagsMapper">

	<select id="showAllparentbag" resultType="parentbags">
		SELECT * FROM parentbags LIMIT #{pager.offset}, #{pager.rows}
	</select>
<insert id="insert" parameterType="cn.xcdm.adminBag.po.Parentbags">
        insert into parentbags
        VALUES(#{parentbags.parentbagsid},#{parentbags.longitude},#{parentbags.latitude},#{parentbags.address},#{parentbags.updated},#{parentbags.created})</insert>

 

(1)检查 namespace值是否正确,在MyBatis中,Mapper中的namespace用于绑定Dao接口的,即面向接口编程。它的好处在于当使用了namespace之后就可以不用写接口实现类,业务逻辑会直接通过这个绑定寻找到相对应的SQL语句进行对应的数据处理。检查其值是否和相应的Mapper接口名相等。(区分大小写)

(2)检查resultType是否正确它既不能被指定为List也不能指定为ArrayList因为返回的类型是java.util.List<Parentbags>类型,所以要指定为parentbags的全路径,当然我在此处已经配置了SqlSessionFactoryBean的typeAliasesPackage属性来设置TypeAliases(类别名),如没有殊说明则则默认为类名首字母小写(当然写成大写也可以用)。

	<!-- SqlSessionFactory -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<!-- 数据源 -->
		<property name="dataSource" ref="dataSource"></property>
		<!-- 别名 -->
		<property name="typeAliasesPackage" value="cn.xcdm.adminBag.po"></property>
	</bean> 

当然大小写可以配置 也可在javabean 加上注解@Alias 来自定义别名, 例如: @Alias(parentbags)

(3)检查parameterType值是否正确。包括:

1.基本数据类型:java.lang.Longjava.lang.Integer,java.lang.String,java.lang.Date

2复杂数据类型:java.util.ArrayListjava.util.HashListjava.util.HashMap

3.实体类。在是实体类时候 ,若报错可用@Param解决。具体可见我的另一篇博客 Mybatis-There is no getter for property named 'xxx' in 'class




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值