Mybatis学习

Mybatis定义:Mybatis是一款优秀的持久层框架,用于简化JDBC的开发;

持久层的定义:负责将数据保存到数据库的那一层代码;

JDBC的缺点:1.硬编码 (~注册驱动,获取连接 ~SQL语句 )   2.操作繁琐(~手动设置参数 ~手动封装结果集)

这次使用的是mapper代理的方式完成(1.定义一个pojo,里面放实体类例如User,对应数据库表里的属性。2.配置pom.xml 还有核心配置文件 3.配置sqlu映射文件在resource下,4.写Mapper接口,其中sql映射文件与mapper接口的路径要一致,才能方便使用mapper代理,最后编写测试)

 

 

 

首先需要导入maven模块,在pom.xml文件下导入坐标(mybatis、junit、mysql连接等)

 <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.0</version>
    </dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.49</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.20</version>
    </dependency>
    <dependency>
      <groupId>ch.qos.logback</groupId>
      <artifactId>logback-classic</artifactId>
      <version>1.3.0-alpha14</version>
    </dependency>
    <dependency>
      <groupId>ch.qos.logback</groupId>
      <artifactId>logback-core</artifactId>
      <version>1.2.3</version>
    </dependency>
      <dependency>
          <groupId>org.testng</groupId>
          <artifactId>testng</artifactId>
          <version>RELEASE</version>
          <scope>compile</scope>
      </dependency>
  </dependencies>

第二步:在resource文件下添加mybatis的核心配置文件mybatis-config.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="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

第三步:配置sql映射文件:统一管理sql语句

<?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">
<!--
namespace:名称空间
-->
<mapper namespace="com.matao.mapper.UserMapper">
    <select id="selectAll" resultType="com.matao.pojo.User">
        select * from tb_user;
    </select>
    <!--<select id="selectAll1" resultType="com.matao.pojo.Brand">
        select * from tb_brand;
    </select>-->
</mapper>

第四步,在mybatis-config.xml配置加载sql映射文件

<!--加载SQL映射文件-->
    <mappers>
        <!--<mapper resource="com/matao/mapper/UserMapper.xml"/>-->
        <!--mapper代理-->
        <!--如果Mapper接口名称和SQL映射文件名称相同,并在同一目录下,则可以使用包扫描的方式简化sql映射文件的加载-->
        <package name="com.matao.mapper"/>
    </mappers>

第五步:定义与sql映射文件名相同的Mapper接口,并且将mapper接口和sql映射文件放置在同一目录下。

 

 

 在UserMapper接口里定义方法,方法名就是sql映射文件中sql语句的id,并保持参数类型和返回值类型一致

package com.matao.mapper;

import com.matao.pojo.Brand;
import com.matao.pojo.User;

import java.util.List;

public interface UserMapper {
    List<User> selectAll();

    //List<Brand> selectAll1();
}

最后写测试

package com.matao.pojo;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

public class MybatisDemo {
    public static void main(String[] args) throws IOException {
        //1.加载mybatis核心配置文件,获取SqlSessionFactory
        String resource = "org/mybatis/example/mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);


        //2.获取Sqlsession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //3.执行sql
        List<User> users = sqlSession.selectList("test.selectAll");


        System.out.println(users);

        sqlSession.close();
    }
}

其中还有许多小问题,小知识巩固

 

posted @ 2022-03-12 17:24  学号java不是梦  阅读(35)  评论(0)    收藏  举报