猿问
下载APP

关于springboot 整合 mybatis dao一直自动注入失败?

springboot 整合 mybatis dao一直自动注入失败


收到一只叮咚
浏览 87回答 3
3回答

哔哔one

一、可能出现问题的原因1.sqlmapConfig.xml文件头写错2.namespace写错3.包在工程中放错层级,也会报这个错误.因为Springboot,是通过main方法启动工程的,要求是,通过main项目入口启动的模块,必须和他同级或是它的子包,不能放到他外面,否则,会报错二、会导致,报,dao注入失败1.学习springboot整合mybaits,根据demo做2.看整个流程都没问题了,因为配置本身就不多3.配置文件主要东西都在application.properties中

幕布斯7119047

因spring3发布时mybatis还没有出正式版本,所以spring没有整合最新的mybatis.不过社区倒是开发了一个中间件。需要的jar包mybatis-3.0.6.jarmybatis-spring-1.0.2.jar要点:在spring中配置mybatis工厂类2.在dao层使用spring注入的的工具bean对数据进行操作整合时,可以有四种方式来使用mybatis进行数据处理。spring 中必须的配置。spring的配置文件中加入以下内容<!-- MyBatis配置 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="c3p0DataSource" /><property name="configLocation" value="/WEB-INF/config/db/MyBatisConfiguration.xml" /><property name="mapperLocations" value="/WEB-INF/config/db/*Mapper.xml" /><property name="typeAliasesPackage" value="${mybatis.alias.basepackage}" /></bean>SqlSessionFactoryBean (必需)就是中间件所需的处理类2.dataSource &nbsp;(必需)spring中数据源引用3.configLocation &nbsp;(可选)Mybatis自身的配置文件,一般用来声明别名4.mapperLocation &nbsp;(可选)mybatis的映射文件5.typeAliasesPackage (可选)要映射类的包路径,如果使用了这种方式,则configLocation中不必再进行声明使用mybatis进行数据处理的四种方式(SqlSessionTemplate/SqlSessionDaoSupport/MapperFactoryBean/MapperScannerConfigurer)不同方式的特点SqlSessionTemplate 这个需要写配置文件,在实现类中注入sqlsession,再使用sqlsession,是细颗粒控制SqlSessionDaoSupport &nbsp;这个只需要在实现类中继承特殊类就可以使用sqlsessionMapperFactoryBean &nbsp;这个要写配置文件,把对应的所有接口在配置文件中引用即可,无需写实现类MapperScannerConfigurer 这个要写配置文件,只要给出接口所在的包即可,会自动把包中的接口引入,无需写实现类SqlSessionTemplate配置文件加入新配<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate"><constructor-arg index="0" ref="sqlSessionFactory" /><constructor-arg index="1" value="BATCH" /><!--- 如果想要进行批量操作可加入这个属性 -></bean>注入sqlsession()@Reasource //使用spring3的注解注入private SqlSession sqlSession;使用sqlsession来进行操作public User getUser(String userId) {return (User) sqlSession.selectOne("org.mybatis.spring.sample.mapper.UserMapper.getUser", userId);}SqlSessionDaoSupport(sqlSessionFactory会被spring自动装配,不需要手动注入)继承SqlSessionDaoSupport类public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao {}使用getSqlSession()方法取sqlSession来进行数据处理public User getUser(String userId) {return (User) getSqlSession().selectOne("org.mybatis.spring.sample.mapper.UserMapper.getUser", userId);}MapperFactoryBean写配置文件,引入每个DAO接口<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"><property name="mapperInterface" value="org.mybatis.spring.sample.mapper.UserMapper" /><property name="sqlSessionFactory" ref="sqlSessionFactory" /></bean>在业务层可直接注入dao的接口进行操作MapperScannerConfigurer写配置文件,配置包名将自动引入包中的所有接口<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="org.mybatis.spring.sample.mapper" /></bean>在业务层可直接注入DAO接口操作,注入时使用的是接口名,其首字母小写注意:如果有别的实现类,其提供的名称如果是接口名,且首字母小写,则会在启动时出现冲突错误

慕雪6442864

一、可能出现问题的原因1.sqlmapConfig.xml文件头写错2.namespace写错3.包在工程中放错层级,也会报这个错误.因为Springboot,是通过main方法启动工程的,要求是,通过main项目入口启动的模块,必须和他同级或是它的子包,不能放到他外面,否则,会报错二、会导致,报,dao注入失败1.学习springboot整合mybaits,根据demo做2.看整个流程都没问题了,因为配置本身就不多3.配置文件主要东西都在application.properties中
打开App,查看更多内容
随时随地看视频慕课网APP
我要回答