mybatis 创建SqlSessionFactory

mybatis 创建SqlSessionFactory创建SqlSessionFactory有两种方式:一种是通过XML,另一种是通过Java代码。Stringresource="org/mybatis/example/mybatis-config.xml";InputStreaminputStream=Resources.getResourceAsStream(resource);SqlSessionFactorysqlSess…

大家好,又见面了,我是你们的朋友全栈君。

创建SqlSessionFactory有两种方式:一种是通过XML,另一种是通过Java代码。

String resource = "org/mybatis/example/mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

XML 配置文件(configuration XML)中包含了对 MyBatis 系统的核心设置,包含获取数据库连接实例的数据源(DataSource)和决定事务作用域和控制方式的事务管理器(TransactionManager)。给出一个简单的示例:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
    <mapper resource="org/mybatis/example/BlogMapper.xml"/>
  </mappers>
</configuration>

不使用XML文件的方式如下:

DataSource dataSource = BlogDataSourceFactory.getBlogDataSource();
TransactionFactory transactionFactory = new JdbcTransactionFactory();
Environment environment = new Environment("development", transactionFactory, dataSource);
Configuration configuration = new Configuration(environment);
configuration.addMapper(BlogMapper.class);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);

SqlSessionFactoryBuilder类有很多个build方法,对应了不同的输入参数:

public SqlSessionFactory build(InputStream inputStream) { 
   
return build(inputStream, null, null);
}

public SqlSessionFactory build(InputStream inputStream, String environment) { 
   
return build(inputStream, environment, null);
}

public SqlSessionFactory build(InputStream inputStream, Properties properties) { 
   
return build(inputStream, null, properties);
}

public SqlSessionFactory build(InputStream inputStream, String environment, Properties properties) { 
   
try { 
   
  XMLConfigBuilder parser = new XMLConfigBuilder(inputStream, environment, properties);
  return build(parser.parse());
} catch (Exception e) { 
   
  throw ExceptionFactory.wrapException("Error building SqlSession.", e);
} finally { 
   
  ErrorContext.instance().reset();
  try { 
   
    inputStream.close();
  } catch (IOException e) { 
   
    // Intentionally ignore. Prefer previous error.
  }
}
}

public SqlSessionFactory build(Configuration config) { 
   
return new DefaultSqlSessionFactory(config);
}
  • 总的来说分为两种输入参数,一种是为通过XML创建SqlSessionFactory服务,另一种是为完全通过Java代码创建SqlSessionFactory服务。从以上源码我们也能够看出,XML文件中的元素也对应着Java中的对象,例如properties。
  • 前面三种重载方法表明,当配置文件中全部信息都包含时,则使用只有InputStream一个参数的build方法,当XML文件中缺少哪个元素时,可以通过Java代码的方式创建并传入build方法中,比如可以传入properties,这样就能够实现数据库密码不被暴露。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/137688.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号