微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

mybatis 加载配置文件的方法两种方式

一. 使用sqlSessionFactory 的 mapperLocations 进行加载,

<!-- SessionFactory --> 
 <bean id="sqlSessionFactory" class="org.mybatis.spring.sqlSessionfactorybean" scope="singleton"> 
 <property name="dataSource" ref="dataSource" /> 
 <property name="configLocation" value="classpath:mybatis-config.xml" /> 
 <!-- 映射文件路径,可以集中写到一个地方,也可以与dao写到一个地方,支持多个路径,支持通配符--> 
 <property name="mapperLocations" value="classpath:mapper/*.xml,classpath:com/sunny/shop/*/dao/*.xml"></property> 
 </bean> 

此种方法可以使用通配符,可以指定位置,可以使用多个位置,

二. 使用MapperScannerConfigurer进行扫描

<!-- 扫描指定包下的所有接口,创建代理类,如果MysqL配置文件名与接口名相同的话,可以不用一一配置 --> 
 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 
  <property name="basePackage" value="com.sunny.shop" /> 
  <property name="sqlSessionfactorybeanName" value="sqlSessionFactory"></property> 
</bean> 

此种方法可以扫描指定包下的接口,如果需要扫描配置文件,则配置文件须与对应的DAO接口处于同一目录,且名字必须相同

三.配置 mybatis 的 mapper

<mappers> 
 <!-- 既可写映射文件,也可写对应的接口 --> 
  
  <!--<mapper resource="com/mybatis/student/StudentMapper.xml" /> 
  <mapper resource="com/mybatis/classes/ClassesMapper.xml" /> 
   <mapper class="com.sunny.shop.user.dao.UserDao" /> 
  --> 
 </mappers> 

前两种都是在spring的配置文件中配置的,在 mybatis 的配置文件中配置 <mappers>节点

PS:下面给大家介绍下mybatis 加载配置文件的两种方式

package com.atguigu.day03_mybaits.test;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.sqlSession;
import org.apache.ibatis.session.sqlSessionFactory;
import org.apache.ibatis.session.sqlSessionFactoryBuilder;
public class Test {
public static void test1(){
///加载mybatis的配置文件(它也加载关联的映射文件)
String str="conf.xml";
InputStream is=Test.class.getClassLoader().getResourceAsstream(str);
//构建sqlSession的工厂
sqlSessionFactory factory=new sqlSessionFactoryBuilder().build(is);
sqlSession session=factory.openSession();
//映射sql的标识字符串,是在影射文件中找到namespace+“”+select中的id
String statement="com.atguigu.day03_mybaits.userMapper.getUser";
//执行查询返回一个唯一user对象的sql
User user=session.selectOne(statement,1);
System.out.println(user);
}
public static void test2() throws IOException{
///加载mybatis的配置文件(它也加载关联的映射文件)
String resource = "conf.xml"; 
//加载mybatis的配置文件(它也加载关联的映射文件)
Reader reader = Resources.getResourceAsReader(resource); 
//构建sqlSession的工厂
sqlSessionFactory factory=new sqlSessionFactoryBuilder().build(reader);
sqlSession session=factory.openSession();
//映射sql的标识字符串,2);
System.out.println(user);
}
public static void main(String[] args) throws IOException {
test1();
test2();
}
}

总结

以上所述是小编给大家介绍的mybatis 加载配置文件方法(两种方式),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐