您的位置:首页 > 数据库

MyBatis核心SqlSessionFactory的创建

2016-02-29 11:17 393 查看
SqlSessionFactory是每个MyBatis应用的核心

 

其实现方式有两种,使用配置文件或使用JAVA编码。

 

1.配置文件实现

Xml代码  


<?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="${usern
4000
ame}" />  

                <property name="password" value="${password}" />  

            </dataSource>  

        </environment>  

    </environments>  

      

    <mappers>  

        <mapper resource="org/mybatis/example/BlogMapper.xml" />  

    </mappers>  

      

</configuration>   

 使用时利用下面代码进行初始化

Java代码  


String resource = "org/mybatis/example/Configuration.xml";   

Reader reader = Resources.getResourceAsReader(resource);   

SqlSessionFactory sqlMapper = new SqlSessionFactoryBuilder().build(reader);  

 

2.使用编码实现

Java代码  


DataSource dataSource = new PooledDataSource("com.mysql.jdbc.Driver",  

                        "jdbc:mysql://localhost/mybatis?userUnicode=true&characterEncoding=utf8", "root", "mysql");  

        Environment environment = new Environment("test", new JdbcTransactionFactory(), dataSource);  

        Configuration configuration = new Configuration(environment);  

        configuration.addMapper(TestDao.class);  

        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);  

 

 

生命同期问题

SqlSessionFactoryBuilder 是用过即丢,其生命周期只存在于方法体内

SqlSessionFactory 单例,存在于整合应用运行时
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: