MyBatis的XML配置及加载方式 —— Mybatis(二)

添加Mybatis的坐标

<dependencies>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.5</version>
    </dependency>

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.6</version>
        <scope>runtime</scope>
    </dependency>
</dependencies>

  

配置SqlMapConfig.xml

  用于配置Mybatis的环境和映射配置信息。

<?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> <!-- 配置 mybatis 的环境 --> <environments default="mysql"> <!-- 配置 mysql 的环境 --> <environment id="mysql"> <!-- 配置事务的类型 --> <transactionManager type="JDBC"></transactionManager> <!-- 配置连接数据库的信息:用的是数据源(连接池) --> <dataSource type="POOLED">
          <property name="driver" value="com.mysql.jdbc.Driver"/>           <property name="url" value="jdbc:mysql://localhost:3306/cast"/>           <property name="username" value="root"/>           <property name="password" value="1234"/> </dataSource> </environment> </environments> <!-- 告知 mybatis 映射配置的位置 --> <mappers> <mapper resource="com/itcast/dao/IUserDao.xml"/> </mappers> </configuration>

  

持久层接口的映射文件

  创建位置必须和持久层接口在相同的包当中,名称必须以持久层接口名称命名文件名,扩展名是.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper 
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 

<mapper namespace="com.itcast.dao.IUserDao">
  <!-- 配置查询所有操作 --> 
  <!-- id 方法的名称 -->
  <!-- resultType 全类名>
   <select id="findAll" resultType="com.itcast.domain.User">
       select * from user
   </select>
</mapper>

 

  

通过测试类,使用MyBatis

public class MybatisTest {
    public static void main(String[] args)throws Exception {
        //1.读取配置文件
        InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");

        //2.创建 SqlSessionFactory 的构建者对象
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
 
       //3.使用构建者创建工厂对象 SqlSessionFactory
        SqlSessionFactory factory = builder.build(in);

        //4.使用 SqlSessionFactory 生产 SqlSession 对象
        SqlSession session = factory.openSession();

        //5.使用 SqlSession 创建 dao 接口的代理对象
        IUserDao userDao = session.getMapper(IUserDao.class);

        //6.使用代理对象执行查询所有方法
        List<User> users = userDao.findAll();
        for(User user : users) {
            System.out.println(user);
        }

        //7.释放资源
        session.close();
        in.close();
    } 
}    

  

  使用MyBatis是非常容易的一件事情,只需要编写Dao层接口并且按照MyBatis要求编写两个配置文件,就可以实现功能。

 

posted @ 2020-04-01 13:44  观沧听白  阅读(769)  评论(0)    收藏  举报