国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

SpringBoot整合mybatis常見問題(小結)

瀏覽:4日期:2023-04-01 17:14:28
Spring中常見問題

1.NoSuchBeanDefinitionException

SpringBoot整合mybatis常見問題(小結)

2.’..Service’ that could not be found service找不到

SpringBoot整合mybatis常見問題(小結)

3.port 80 was already in use 端口號被占用

SpringBoot整合mybatis常見問題(小結)

4.TemplateInputException 模板解析異常或找不到模板

1.檢查模板所在的目錄是否與配置的前綴目錄相同 2.檢查返回的模板是否存在,返回值類型是否一致 3.檢查配置前綴時是否以'/'斜杠結尾 4.控制層的url與客戶端的ur是否一致

SpringBoot整合mybatis常見問題(小結)

5. 404異常 訪問資源不存在

SpringBoot整合mybatis常見問題(小結)

6. 500異常 500異常要查看控制臺

SpringBoot整合mybatis常見問題(小結)

Mybatis中常見問題

1.springboot中添加maven依賴

SpringBoot整合mybatis常見問題(小結)

2.BadSqlGrammarException 錯誤的sql語句

SpringBoot整合mybatis常見問題(小結)

SpringBoot整合mybatis常見問題(小結)

3.BindingException 綁定異常

1.檢查映射文件的路徑配置與實際存儲位置是否一致 2.檢查dao接口的類名是否與映射文件的namespace值相同(不能有空格) 3.檢查dao接口中的方法名是否在映射文件中有對應的id

SpringBoot整合mybatis常見問題(小結)

SpringBoot整合mybatis常見問題(小結)

SpringBoot整合mybatis常見問題(小結)

SpringBoot整合mybatis常見問題(小結)

4.IllegalArgumentException

原因:同樣說我sql映射是否出現了重復性的定義(例如:分別以注解方式和xml配置文件方式進行定義,也就是說在同一個namespace下出現了重復的元素id)

SpringBoot整合mybatis常見問題(小結)

5.SAXParseException xml解析問題

SpringBoot整合mybatis常見問題(小結)

補充問題一:Mapper類 autowired失敗

原因:掃描mapper包沒有配置或配置不正確

解決:

方案一:

1. 啟動類加@MapperScan('mapperPackagePath')

方案二:

增加配置類:

package com.yx.readingwebsite.config; import org.mybatis.spring.mapper.MapperScannerConfigurer;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; /** * MapperScannerConfigurer 配置DAO層 */ @Configurationpublic class MyBatisMapperScannerConfig { @Bean public MapperScannerConfigurer getMapperScannerConfigurer(){ MapperScannerConfigurer msc = new MapperScannerConfigurer(); msc.setSqlSessionFactoryBeanName('sqlSessionFactory'); msc.setBasePackage('com.yx.readingwebsite.mapper'); return msc; }}問題二:Mapper掃描成功后,繼續報錯,org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

原因:xml的mapper SQL 和 Mapper接口沒有綁定

解決:

方案一:全局配置文件application.yml增加mybatis配置【xml mapper包在resource目錄下】

mybatis: mapper-locations: classpath:mapper/*.xml

方案二:增加配置類

package com.yx.readingwebsite.config; import org.apache.ibatis.session.SqlSessionFactory;import org.mybatis.spring.SqlSessionFactoryBean;import org.mybatis.spring.SqlSessionTemplate;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.core.io.Resource;import org.springframework.core.io.support.PathMatchingResourcePatternResolver;import org.springframework.jdbc.datasource.DataSourceTransactionManager;import org.springframework.transaction.PlatformTransactionManager;import org.springframework.transaction.annotation.EnableTransactionManagement;import org.springframework.transaction.annotation.TransactionManagementConfigurer; import javax.sql.DataSource; /** * 配置MyBatis,引入數據源,sqlSessionFactory,sqlSessionTemplate,事務管理器 */ @Configuration //配置類@EnableTransactionManagement //允許使用事務管理器public class MyBatisModelConfig implements TransactionManagementConfigurer { @Autowired private DataSource dataSource; @Bean(name = 'sqlSessionFactory') public SqlSessionFactory getSqlSessionFactory(){ SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean(); ssfb.setDataSource(dataSource); //設置數據源 ssfb.setTypeAliasesPackage('com.yx.readingwebsite.model'); //設置掃描模型包【po】 try { Resource[] resources = new PathMatchingResourcePatternResolver() .getResources('classpath:mapper/*.xml'); ssfb.setMapperLocations(resources); return ssfb.getObject(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(); } } @Bean //獲得Session 模板,從而獲得Session public SqlSessionTemplate getSqlSessionTemplate(SqlSessionFactory sqlSessionFactory){ return new SqlSessionTemplate(sqlSessionFactory); } @Override //事務管理器 public PlatformTransactionManager annotationDrivenTransactionManager() { return new DataSourceTransactionManager(dataSource); }}

需要注意的是,xml版的mybatis一定要在sqlSessionFactory中指定mapperLocations,即下圖

SpringBoot整合mybatis常見問題(小結)

總結:兩種配置方案。方案一,使用配置類;方案二,使用配置文件。完整配置如下:

方案一:配置類

package com.yx.readingwebsite.config; import org.apache.ibatis.session.SqlSessionFactory;import org.mybatis.spring.SqlSessionFactoryBean;import org.mybatis.spring.SqlSessionTemplate;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.core.io.Resource;import org.springframework.core.io.support.PathMatchingResourcePatternResolver;import org.springframework.jdbc.datasource.DataSourceTransactionManager;import org.springframework.transaction.PlatformTransactionManager;import org.springframework.transaction.annotation.EnableTransactionManagement;import org.springframework.transaction.annotation.TransactionManagementConfigurer; import javax.sql.DataSource; /** * 配置MyBatis,引入數據源,sqlSessionFactory,sqlSessionTemplate,事務管理器 */ @Configuration //配置類@EnableTransactionManagement //允許使用事務管理器public class MyBatisModelConfig implements TransactionManagementConfigurer { @Autowired private DataSource dataSource; @Bean(name = 'sqlSessionFactory') public SqlSessionFactory getSqlSessionFactory(){ SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean(); ssfb.setDataSource(dataSource); //設置數據源 ssfb.setTypeAliasesPackage('com.yx.readingwebsite.model'); //設置掃描模型包【po】 try { Resource[] resources = new PathMatchingResourcePatternResolver() .getResources('classpath:mapper/*.xml'); ssfb.setMapperLocations(resources); return ssfb.getObject(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(); } } @Bean //獲得Session 模板,從而獲得Session public SqlSessionTemplate getSqlSessionTemplate(SqlSessionFactory sqlSessionFactory){ return new SqlSessionTemplate(sqlSessionFactory); } @Override //事務管理器 public PlatformTransactionManager annotationDrivenTransactionManager() { return new DataSourceTransactionManager(dataSource); }}

package com.yx.readingwebsite.config; import org.mybatis.spring.mapper.MapperScannerConfigurer;import org.springframework.boot.autoconfigure.AutoConfigureAfter;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; /** * MapperScannerConfigurer 配置DAO層 */ @Configuration@AutoConfigureAfter(MyBatisModelConfig.class)public class MyBatisMapperScannerConfig { @Bean public MapperScannerConfigurer getMapperScannerConfigurer(){ MapperScannerConfigurer msc = new MapperScannerConfigurer(); msc.setSqlSessionFactoryBeanName('sqlSessionFactory'); msc.setBasePackage('com.yx.readingwebsite.mapper'); return msc; }}

方案二:配置文件 application.yml

spring: datasource: url: jdbc:mysql://127.0.0.1:3306/readingWebsite?useUnicode=true&characterEncoding=utf-8 username: password: driver-class-name: com.mysql.jdbc.Driver max-active: 100 max-idle: 10 max-wait: 10000 default-auto-commit: false time-between-eviction-runs-millis: 30000 min-evictable-idle-time-millis: 30000 test-while-idle: true test-on-borrow: true test-on-return: true validation-query: SELECT 1 mybatis: mapper-locations: classpath:mapper/*.xml

package com.yx.readingwebsite; import org.mybatis.spring.annotation.MapperScan;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication@MapperScan('com.yx.readingwebsite')public class ReadingWebsiteApplication { public static void main(String[] args) { SpringApplication.run(ReadingWebsiteApplication.class, args); } }

到此這篇關于SpringBoot整合mybatis常見問題(小結)的文章就介紹到這了,更多相關SpringBoot整合mybatis問題內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 中国成人免费视频 | 亚洲高清视频网站 | 看真人一一级毛片 | 成年女人免费看 | 亚洲欧美日韩在线精品一区二区 | 毛片直接看 | 日韩一级a毛片欧美一级 | 日韩在线专区 | 日韩美三级 | 精品亚洲福利一区二区 | 精品一区二区三区在线视频观看 | 日本一线a视频免费观看 | 202z欧美成人| 视频一区欧美 | gay毛片 | 久久综久久美利坚合众国 | 在线观看亚洲欧美 | 国产精品欧美一区二区三区不卡 | 日韩在线不卡一区在线观看 | 久久久婷| 免费看男女做好爽好硬视频 | 亚洲国产日韩女人aaaaaa毛片在线 | 欧美大尺度免费一级特黄 | 欧美大屁股精品毛片视频 | 国产日产欧产精品精品推荐小说 | 99国产精品久久久久久久日本 | 亚洲 午夜在线一区 | 久久国产乱子伦精品免费不卡 | 日韩成人免费一级毛片 | 欧美精品网站 | 日本特黄a级高清免费酷网 日本特黄特色 | 麻豆第一页 | 亚洲欧美日韩国产制服另类 | 亚洲天堂色视频 | 免费人成在线观看播放国产 | 武松大战潘金莲三级在线 | 亚洲免费观看在线视频 | 日本视频播放免费线上观看 | 91日本在线观看亚洲精品 | 亚洲一区二区免费视频 | 99爱在线精品视频网站 |