0
点赞
收藏
分享

微信扫一扫

mybatis和mybatis-plus同时使用时, 无法使用BaseMapper的公用方法

小时候是个乖乖 2022-03-30 阅读 44
java后端

mybatis-plus无法使用BaseMapper的公用方法

需求:基于原项目进行二次开发,原项目使用的是mybaits 我这里想用mybatis-plus进行模块开发

启动时出现错误:

Invalid bound statement (not found)

原本的mybatis里面再次引入mybatis-plus之后,使用公用的BaseMapper无法使用报错:也就是无法找到sql

解决方案:只需要在你配置数据源的地方,换一个类即可:

 SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();

示例:

  @Bean
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception
{
String typeAliasesPackage = env.getProperty("mybatis.typeAliasesPackage");
String mapperLocations = env.getProperty("mybatis.mapperLocations");
String configLocation = env.getProperty("mybatis.configLocation");
typeAliasesPackage = setTypeAliasesPackage(typeAliasesPackage);
VFS.addImplClass(SpringBootVFS.class);

// final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
MybatisSqlSessionFactoryBean sessionFactory=new MybatisSqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.setTypeAliasesPackage(typeAliasesPackage);
sessionFactory.setMapperLocations(resolveMapperLocations(StringUtils.split(mapperLocations, ",")));
sessionFactory.setConfigLocation(new DefaultResourceLoader().getResource(configLocation));
return sessionFactory.getObject();
}
举报

相关推荐

0 条评论