Mybatis环境搭建详细讲解过程

Mybatis环境搭建

学习记录

第一步

:配置pom.xml,输入相关jar包坐标,maven工程会自动下载jar包,如果下载过慢可配置自己的中央maven库,添加一个阿里云镜像,添加阿里云镜像的方法。传送门:添加阿里云镜像。

<packaging>jar</packaging>
<dependencies>
	//mybatis的主要jar包
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.5</version>
    </dependency>
	//连接MySQL的jar包
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.6</version>
    </dependency>
	//日志打印jar包
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.12</version>
    </dependency>
	//单元测试jar包
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.10</version>
    </dependency>
    
	//有些人这后面两个是不需要的
    <dependency>
        <groupId>org.apache.ibatis</groupId>
        <artifactId>ibatis-core</artifactId>
        <version>3.0</version>
    </dependency>

    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.3.2</version>
    </dependency>
第二步

:创建一个对应数据库中表数据的实体类以及该类的dao接口,mybatis通过调用dao接口的方法去执行想要执行的操作。
此处只用作举例.

实体类代码:

public class User {
    private Integer id;
    private String username;
    private Date brithday;
    private String sex;
    private String address;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public Date getBrithday() {
        return brithday;
    }

    public void setBrithday(Date brithday) {
        this.brithday = brithday;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", brithday=" + brithday +
                ", sex='" + sex + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}

dao接口代码:

public interface UserDao {
    /**
     * 查询所有操作
     * @return
     */
    List<User> findAll();
}
第三步

配置mybatis,这里是主配置文件,用于连接MySQL数据库,以及dao接口的文件位置等信息。其他具体需要看情况进行配置。
创建一个.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的主配置文件 -->
<!-- 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/essy?characterEncoding=utf8"/>
                <property name="username" value="root"/>
                <property name="password" value="123"/>
            </dataSource>
        </environment>
    </environments>

    <!-- 指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件-->
    <!-- mybatis的映射配置文件必须和dao接口的包结构相同,即若dao接口是三级目录配置文件也要是三级目录 -->
    <mappers>
        <mapper resource="com/yang/dao/UserDao.xml"/>
    </mappers>
</configuration>
第四步

配置dao接口的配置文件。该文件是mybatis使用xml文件配置的方式才需要,如果使用注解开发,就不需要该文件。
开启mybatis注解支持,在第三步的配置文件中加上下面这段代码即可

<!-- 指定带有注解的dao接口所在位置 -->
<mappers>
    <mapper class="com.itheima.dao.IUserDao"></mapper>
</mappers>

使用xml配置mybatis,需要给每个dao接口配置其相关文件。

<?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.yang.dao.UserDao">

    <!-- mybatis环境搭建第四步 -->
    <!-- UserDao和UserMapper是一样的 -->
    <!-- 配置查询所有-->
    <!-- id必须是接口中的方法名-->
    <select id="findAll" resultType="com.yang.domain.User">
        select * from user
    </select>

</mapper>

到此mybatis的使用xml配置的环境已经配置完成。下面是一个简单的测试类来测试是否能从数据库中获取到数据。

public class MybatisTest {
    public static void main(String[] args)  throws Exception {
        //1.读取配置文件
        InputStream in= Resources.getResourceAsStream("SqlMapConfig.xml");
        //InputStream in = new FileInputStream("SqlMapConfig.xml"); // 相对路径,项目下的路径
        //2.创建SqlSessionFactory工厂
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        SqlSessionFactory factory=builder.build(in);
        //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.释放资源
        session.close();
        in.close();
    }
}

此博客只做学习记录,不到位的地方请指出。

你可能感兴趣的:(ssm框架)