美文网首页
MyBatis 环境搭建

MyBatis 环境搭建

作者: Edwinpanzzz | 来源:发表于2019-08-06 11:06 被阅读0次

    一、导入坐标

    使用 maven 工程构建项目时,将下面的 dependency 代码置于 pom.xml 文件中:

    <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.26</version>
        </dependency>
    </dependencies>
    

    二、创建实体类和 dao 的接口

    dao 接口:

    public interface UserDao {
        /**
         * 查询所有用户
         * @return list
         */
        public List<User> findAll();
    }
    

    三、创建 MyBatis 的主配置文件 SqlMapConfig.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">
    <!-- mybatis的主配置文件 -->
    <configuration>
        <!-- 配置环境 -->
        <environments default="mysql">
            <!-- 配置mysql的环境 -->
            <environment id="mysql">
                <!-- 配置事务的类型 -->
                <transactionManager type="JDBC"></transactionManager>
                <!-- 配置数据源(连接池) -->
                <dataSource type="POOLED">
                    <!-- 配置连接数据库的4个基本信息 -->
                    <property name="driver" value="com.mysql.jdbc.Driver"/>
                    <property name="url" value="jdbc:mysql://localhost:3306/eesy_mybatis"/>
                    <property name="username" value="root"/>
                    <property name="password" value="root"/>
                </dataSource>
            </environment>
        </environments>
    
        <!-- 指定映射配置文件的位置,映射配置文件指的是每个 dao 独立的配置文件 -->
        <mappers>
            <mapper resource="cn/edwinpan/dao/UserDao.xml"/>
        </mappers>
    </configuration>
    

    四、创建映射配置文件 UserDao.xml

    逐级创建 com/itheima/dao/UserDao.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="cn.edwinpan.dao.UserDao">
        <!--配置 dao 中查询所有的方法 findAll() -->
        <select id="findAll" resultType="cn.edwinpan.domain.User">
            select * from user;
        </select>
    </mapper>
    

    五、注解方式

    可以将映射配置文件 UserDao.xml直接删除,然后修改主配置文件 SqlMapConfig.xml,修改 mappers 内容:

    <mappers>
        <package name="cn.edwinpan.dao"/>
    </mappers>
    

    然后,在 UserDao 接口中添加注解:

    @Select("select * from user;")
    public List<User> findAll();
    

    注意

    1. MyBatis 的映射配置文件位置必须和 dao 接口的包结构相同。
    2. 映射配置文件的 mapper 标签 namespace 属性的取值必须是 dao 接口的全限定类名。
    3. 映射配置文件的操作配置 (select),id 属性的取值必须是 dao 接口的方法名。
    • 当我们遵从上述三项后,在开发中无需再写 dao 的实现类。

    入门案例

    public class MyBatisTest {
        public static void main(String[] args) throws IOException {
            // 1.读取配置文件
            InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
            // 2.创建 SqlSessionFactory 工厂
            SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
            SqlSessionFactory factory = builder.build(inputStream);
            // 3.使用工厂生产 SqlSession 对象
            SqlSession session = factory.openSession();
            // 4.使用 SqlSession 创建 dao 的代理对象
            UserDao userDao = session.getMapper(UserDao.class);
            // 5.使用代理对象执行方法
            List<User> users = userDao.findAll();
            for (User user:
                    users) {
                System.out.println(user);
            }
            // 6.关闭资源
            inputStream.close();
            session.close();
        }
    }
    

    相关文章

      网友评论

          本文标题:MyBatis 环境搭建

          本文链接:https://www.haomeiwen.com/subject/kinbdctx.html