首頁 > 軟體

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

2022-07-20 14:01:56

前言

上一篇我們瞭解了框架相關知識,並且匯入依賴設定了核心檔案,今天就可以開始寫程式碼測試了。

新增框架的步驟

在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內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com