Cause: java.lang.IllegalArgumentException: Mapped Statements collection already contains value for c

java.lang.IllegalStateException: Failed to load ApplicationContext

at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContext(DefaultCacheAwareContextLoaderDelegate.java:125)

at org.springframework.test.context.support.DefaultTestContext.getApplicationContext(DefaultTestContext.java:107)

at org.springframework.test.context.support.DependencyInjectionTestExecutionListener.injectDependencies(DependencyInjectionTestExecutionListener.java:117)

at org.springframework.test.context.support.DependencyInjectionTestExecutionListener.prepareTestInstance(DependencyInjectionTestExecutionListener.java:83)

at org.springframework.test.context.TestContextManager.prepareTestInstance(TestContextManager.java:242)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.createTest(SpringJUnit4ClassRunner.java:227)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner$1.runReflectiveCall(SpringJUnit4ClassRunner.java:289)

at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.methodBlock(SpringJUnit4ClassRunner.java:291)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:246)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:97)

at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)

at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)

at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)

at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)

at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)

at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)

at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)

at org.junit.runners.ParentRunner.run(ParentRunner.java:363)

at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:190)

at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)

at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'favoriteBizImpl': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'tagDaoMybatisImpl': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSession' defined in class path resource [beans-dao.xml]: Cannot resolve reference to bean 'sqlSessionFactory' while setting constructor argument; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [beans-dao.xml]: Invocation of init method failed; nested exception is org.springframework.core.NestedIOException: Failed to parse mapping resource: 'file [D:\JAVAWork\springmvc_05_CloudTags\target\classes\com\yc\dao\favoriteDaoMapper.xml]'; nested exception is org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. Cause: java.lang.IllegalArgumentException: Mapped Statements collection already contains value for com.yc.dao.favoriteDaoMapper.add

at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessPropertyValues(CommonAnnotationBeanPostProcessor.java:321)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1350)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:580)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:503)

at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:317)

at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:315)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)

at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:760)

at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:869)

at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550)

at org.springframework.test.context.support.AbstractGenericContextLoader.loadContext(AbstractGenericContextLoader.java:128)

at org.springframework.test.context.support.AbstractGenericContextLoader.loadContext(AbstractGenericContextLoader.java:60)

at org.springframework.test.context.support.AbstractDelegatingSmartContextLoader.delegateLoading(AbstractDelegatingSmartContextLoader.java:107)

at org.springframework.test.context.support.AbstractDelegatingSmartContextLoader.loadContext(AbstractDelegatingSmartContextLoader.java:243)

at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContextInternal(DefaultCacheAwareContextLoaderDelegate.java:99)

at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContext(DefaultCacheAwareContextLoaderDelegate.java:117)

... 25 more

 

 

解决:一个mapper文件中存在两个操作语句的id相同或重复的情况

 

<think>好的,我现在需要解决用户遇到的Java异常问题:java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for updateStudent。首先,我得回忆一下这个错误的常见原因。根据用户提供的引用内容,这通常是因为MyBatis的映射文件(比如Mapper.xml)没有被正确配置到核心配置文件中,或者命名空间、方法名不匹配导致的。 首先,我应该检查Mapper.xml文件是否被正确加载。用户提到过,如果没有在mybatis-config.xml中配置Mapper.xml,就会出现这个问题。所以第一步是确认mybatis-config.xml中的<mappers>部分是否包含了对应的StudentMapper.xml。例如,是否使用了<mapper resource="路径/StudentMapper.xml"/>或者包扫描的方式。 接下来,需要检查Mapper接口的命名空间是否正确。如果StudentMapper.xml中的namespace属性与对应的Java接口的全限定名不一致,MyBatis就无法找到对应的映射语句。比如,namespace应该是类似com.example.dao.StudentMapper,而用户可能写错了包名或者类名。 然后,查看SQL语句的id是否正确。在这个问题中,异常提示的是updateStudent,所以需要确认StudentMapper.xml中是否有<update id="updateStudent">的语句。可能用户把id写错了,比如拼写错误或者大小写不一致。 另外,还要注意MyBatis的配置是否正确,比如是否启用了驼峰命名转换,或者在动态代理接口时是否存在问题。有时候,如果使用了注解和XML混合的方式,也可能导致冲突,需要确保方法名和id一致。 还有可能的是,项目构建时没有将XML文件打包到目标目录中。比如在Maven项目中,如果XML文件放在src/main/resources以外的位置,可能需要配置<resources>来包含这些文件,否则编译后可能无法找到对应的映射文件,导致异常。 此外,检查是否有重复的id。如果同一个Mapper.xml中有多个相同的id,虽然MyBatis可能不会报错,但这也可能引发不可预期的问题,不过更常见的是直接找不到对应的语句。 最后,建议用户清理并重新构建项目,确保所有配置和文件都被正确加载。如果使用了IDE,可能需要手动刷新或重新编译,避免缓存问题。 总结下来,解决方案的步骤大致是:检查配置文件中的Mapper注册、确认XML中的命名空间和id正确、确保XML文件被正确打包、处理可能的缓存或构建问题。需要一步步引导用户排查这些可能性,直到找到具体的原因。</think>要解决`java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for updateStudent`异常,需逐步排查以下可能原因: --- ### **1. 检查Mapper XML文件是否被正确加载** - **问题**:MyBatis核心配置文件(如`mybatis-config.xml`)未包含对应的Mapper XML文件(如`StudentMapper.xml`)。 - **解决方案**: - 在`mybatis-config.xml`的`<mappers>`标签内,明确添加Mapper文件的路径: ```xml <mappers> <mapper resource="com/example/mapper/StudentMapper.xml"/> </mappers> ``` - 或通过包扫描(需确保XML文件与接口在同一包下): ```xml <mappers> <package name="com.example.mapper"/> </mappers> ``` - 若使用Spring Boot,需在`application.properties`中配置`mybatis.mapper-locations=classpath*:mapper/**/*.xml`[^2]。 --- ### **2. 验证XML中的命名空间与接口全限定名** - **问题**:Mapper XML的`namespace`属性值与对应的Java接口全限定名不一致。 - **示例**: ```xml <!-- StudentMapper.xml --> <mapper namespace="com.example.dao.StudentMapper"> <update id="updateStudent"> UPDATE student SET name=#{name} WHERE id=#{id} </update> </mapper> ``` - 确保接口`StudentMapper`的包路径与`namespace`完全一致。 --- ### **3. 检查SQL语句的id与方法名** - **问题**:XML中定义的SQL语句`id="updateStudent"`与Mapper接口方法名不匹配。 - **示例**: ```java public interface StudentMapper { void updateStudent(Student student); // 方法名必须与XML中的id一致 } ``` --- ### **4. 确保XML文件被正确打包** - **问题**:构建工具(如Maven)未将XML文件打包到`target/classes`目录。 - **解决方案**: - 在`pom.xml`中添加资源过滤配置: ```xml <build> <resources> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.xml</include> </includes> </resource> </resources> </build> ``` --- ### **5. 清理项目并重启IDE** - **问题**:IDE缓存导致未加载最新配置或文件。 - **操作**: 1. 执行Maven命令:`mvn clean install`。 2. 重启IDE(如IntelliJ或Eclipse)。 --- ### **其他可能原因** - **动态代理问题**:确保Mapper接口通过`@Mapper`注解或`@MapperScan`被扫描。 - **重复的SQL语句id**:同一XML文件中避免重复的`id`值。 --- ### **总结流程** 1. 确认Mapper XML已注册到核心配置。 2. 检查`namespace`与接口全限定名是否一致。 3. 核对SQL语句`id`与方法名是否匹配。 4. 验证XML文件是否被正确打包。 5. 清理缓存并重启环境。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值