81,092
社区成员
发帖
与我相关
我的任务
分享
Error starting ApplicationContext. To display the auto-configuration report re-run your application with 'debug' enabled.
2017-05-22 10:51:45.858 ERROR 2076 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter :
***************************
APPLICATION FAILED TO START
***************************
Description:
file [E:\Workspaces\springboot-mybatis\target\classes\springboot\dao\CityDao.class] required a single bean, but 4 were found:
- &cityDao: defined in file [E:\Workspaces\springboot-mybatis\target\classes\springboot\dao\CityDao.class]
- systemEnvironment: a programmatically registered singleton - contextParameters: a programmatically registered singleton - contextAttributes: a programmatically registered singleton
Action:
Consider marking one of the beans as @Primary, updating the consumer to accept multiple beans, or using @Qualifier to identify the bean that should be consumed
## jdbc source
spring.datasource.url=jdbc:mysql://localhost:3306/springbootdb?useUnicode=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
## Mybatis
mybatis.typeAliasesPackage=springboot.entity
mybatis.mapperLocations=classpath\:mapper/*.xml
public interface CityDao {
City get(int id);
}
<?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="springboot.dao.CityDao" >
<resultMap type="springboot.entity.City" id="BaseResultMap">
<id column="id" property="id" />
<result column="province_id" property="provinceId" />
<result column="city_name" property="cityName" jdbcType="VARCHAR"/>
<result column="description" property="description" jdbcType="VARCHAR"/>
</resultMap>
<sql id="Base_Column_List" >
id,province_id,city_name,description
</sql>
<select id="get" parameterType="java.lang.Integer" resultMap="BaseResultMap">
select
<include refid="Base_Column_List"/>
from city
where id = #{id}
</select>
</mapper>
@Service
public class CityServiceImpl implements CityService{
@Autowired
private CityDao cityDao;
public City get(String id){
return cityDao.get(Integer.parseInt(id));
}
}
package springboot;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("springboot.dao")
public class App
{
public static void main( String[] args )
{
SpringApplication.run(App.class, args);
}
}