Java Mybatis框架由淺入深全解析中篇

前言

上一篇我們瞭解瞭框架相關知識,並且導入依賴配置瞭核心文件,今天就可以開始寫代碼測試瞭。

添加框架的步驟

在idea中添加數據庫的可視化

這裡需要註意:很多小夥伴鏈接不成功,這個時候要修改一下自己的驅動版本,盡量與數據庫版本一致

添加jdbc.properties屬性文件(數據庫配置)

jdbc.driverclassName=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=*******

這裡有個小細節,新版數據庫驅動的類型不要寫錯 com.mysql.cj.jdbc.Driver

設置完這個就可以連接到數據庫瞭。

添加SqlMapCongig.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>
<!--   讀取屬性文件(jdbc.properties)
    屬性:
        resources:從resouces目錄下找指定名稱的文件加載
        url:使用絕對路徑加載屬性文件
-->
<properties resource="jdbc.properties"></properties>
<!--    配置數據庫的環境變量(數據庫鏈接配置)
        default:使用下面的environment標簽下的id屬性進行指定配置
-->
<!--    <settings>-->
<!--        <setting name="" value=""/>-->
<!--    </settings>-->
<environments default="development">
<!--    開發時再公司使用的數據庫配置
        id;就是提供給environment的default屬性使用
        -->
    <environment id="development">
<!--        配置事務管理器
            type:指定事務管理的方式
                JDBC:事務的控制交給管理員來處理
                MANAGED:由容器(Spring)來管理事務
-->
        <transactionManager type="JDBC"></transactionManager>
<!--        配置數據源:
            type:指定不同的配置方式
                JNDI:java命名目錄接口,在服務器端進行數據庫連接池的管理
                POOLED:使用數據庫連接池
                UNPOOLED:不使用數據庫連接池
-->
        <dataSource type="POOLED">
<!--      配置數據庫連接的基本參數
            private String driver;
            private String url;
            private String username;
            private String password;
-->
            <property name="driver" value="${jdbc.driverclassName}"/>
            <property name="url" value="${jdbc.url}"/>
            <property name="username" value="${jdbc.username}"/>
            <property name="password" value="${jdbc.password}"/>
        </dataSource>
    </environment>
<!--在傢時候數據庫配置-->
<!--    <environment id="home">-->
<!--        <transactionManager type=""></transactionManager>-->
<!--        <dataSource type=""></dataSource>-->
<!--    </environment>-->
<!--&lt;!&ndash;上線的數據庫配置&ndash;&gt;-->
<!--    <environment id="online">-->
<!--        <transactionManager type=""></transactionManager>-->
<!--        <dataSource type=""></dataSource>-->
<!--    </environment>-->
</environments>
<!--    註冊mappe.xml文件
        resouces:從resouces目錄下找指定名稱的文件註冊
        url:使用絕對路徑註冊
        class:動態代理方式下的註冊
-->
    <mappers>
        <mapper resource="StudentMapper.xml"></mapper>
    </mappers>
</configuration>

創建實體類Student用來封裝數據

package com.longlong.pojo;
import java.util.Objects;
/**
 * @Author DELL longlong
 * @Date 2022/7/1 14:51
 * @Version 1.0
 * @Function 實體類
 */
public class Student {
    private Integer id;
    private String name;
    private String email;
    private Integer age;
    public Student() {
    }
    public Student(String name, String email, Integer age) {
        this.name = name;
        this.email = email;
        this.age = age;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return Objects.equals(id, student.id) && Objects.equals(name, student.name) && Objects.equals(email, student.email) && Objects.equals(age, student.age);
    }
    @Override
    public int hashCode() {
        return Objects.hash(id, name, email, age);
    }
    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", email='" + email + '\'' +
                ", age=" + age +
                '}';
    }
}

添加增刪改查

添加完成學生表的增刪改查的功能的StudentMapper.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:是整個文件的打標簽,用來區分開始和結束xml文件
    屬性:
        namespace:指定命名空間(相當於包名),用來區分不同mapper.xml
        文件中的相同id
-->
<mapper namespace="ll">
<!--    完成查詢全部學生的功能
        List<Student> getAll();
        resultType:指定查詢返回的結果集的類型,如果是集合,則必須是泛型
        parameterType:如果有參數,則通過他來完成指定參數的類型
-->
    <select id="getAll" resultType="com.longlong.pojo.Student" >
        select *
        from student
    </select>
</mapper>

這裡要說明一下,為瞭簡單明瞭,暫時隻實現瞭查詢全部的功能

創建測試類進行功能測試

最激動人心的時刻,要進行測試瞭

package com.longlong.test;
import com.longlong.pojo.Student;
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 org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
/**
 * @Author DELL longlong
 * @Date 2022/7/3 19:32
 * @Version 1.0
 * @Function
 */
public class Mytest {
   @Test
    public void testGetAll() throws IOException {
       InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
       SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
       SqlSession sqlSession = factory.openSession();
       List<Student> list = sqlSession.selectList("ll.getAll");
//       list.forEach(student -> System.out.println(student));
       for (Student student : list){
           System.out.println(student);
       }
       System.out.println("OK");
      sqlSession.close();
   }
}

運行結果

顯示這樣就表示我們的測試是成功的,祝賀一下吧!!!

總結

今天我們完成瞭第一次使用mybatis框架,並且成功瞭。開心呢!!!

下面就要深入學習配置文件的標簽和屬性,運行過程,作用!!!

本次源碼放在代碼倉庫gitee,自取鏈接

到此這篇關於Java Mybatis框架由淺入深全解析中篇的文章就介紹到這瞭,更多相關Java Mybatis內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: