今天在使用mybatis集成Spring时遇到了一个曾经遇到过的问题,先看一下使用swagger
测试返回的错误
一般我们看到"status": 500
的时候自然能够想到是后台除了问题,这里说在你的Mapper中找不到getAllStocks
的方法,很显然你是能够在你的代码中找到这个方法的。那么应该就Mapper的问题了。
首先对比mapper.xml
中的namespace有没有问题
<?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="com.example.stock.mapper.StockMapper" >
<resultMap id="BaseResultMap" type="com.example.stock.model.Stock" >
<!--
WARNING - @mbg.generated
-->
<id column="id" property="id" jdbcType="INTEGER" />
<result column="stock_name" property="stockName" jdbcType="VARCHAR" />
<result column="price" property="price" jdbcType="REAL" />
<result column="rating" property="rating" jdbcType="INTEGER" />
<result column="category" property="category" jdbcType="VARCHAR" />
<result column="description" property="description" jdbcType="VARCHAR" />
<result column="deleted" property="deleted" jdbcType="BIT" />
</resultMap>
</mapper>
没有问题之后再检查方法名又没有对上
<select id="getAllStocks" resultMap="BaseResultMap">
SELECT * FROM stock
</select>
发现都没有问题时,百度,Google,都只找到了以上几种可能方案,最后的最后只能去问老师,然后居然发现是在application.properties
中少了一段关于mybatis
的配置,如下:
mybatis.typeAliasesPackage=com.test.shiro.entity
mybatis.mapperLocations=classpath:mapper/*.xml
主要是下面一句配置,是通过路径去对应mapper.xml
中的mapper文件的。加上之后才解决问题。
另外此处加一句,如果有如下错误
Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.example.stock.mapper.StockMapper' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
并且项目没有运行起来则是没有在启动类中添加注解
@MapperScan(basePackages = "com.example.stock.mapper")