[mybatis]快速搭建一個mybatis程式,實現對數據的增刪改查

来源:https://www.cnblogs.com/lumanmanqixiuyuanxi/archive/2022/07/23/16512525.html
-Advertisement-
Play Games

什麼是 MyBatis? MyBatis 是一款優秀的持久層框架,它支持自定義 SQL、存儲過程以及高級映射。 MyBatis 免除了幾乎所有的 JDBC 代碼以及設置參數和獲取結果集的工作。 MyBatis 可以通過簡單的 XML 或註解來配置和映射原始類型、介面和 Java POJO(Plain ...


什麼是 MyBatis?

  • MyBatis 是一款優秀的持久層框架,它支持自定義 SQL、存儲過程以及高級映射。

  • MyBatis 免除了幾乎所有的 JDBC 代碼以及設置參數和獲取結果集的工作。

  • MyBatis 可以通過簡單的 XML 或註解來配置和映射原始類型、介面和 Java POJO(Plain Old Java Objects,普通老式 Java 對象)為資料庫中的記錄。

  • MyBatis本是apache的一個開源項目iBatis,2010年這個項目由apache software foundation遷移到了[google code](https://baike.baidu.com/item/google code/2346604),並且改名為MyBatis。2013年11月遷移到Github

持久層

  • 持久化就是將程式的數據在持久狀態轉化的過程
  • 記憶體,斷電即逝

為什麼需要mybatis

  • 幫助程式員將數據存到資料庫中。

  • 方便

  • 傳統的jdbc代碼太複雜了,簡化,框架,自動化

  • 簡單易學:本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar文件+配置幾個sql映射文件。

  • 靈活:mybatis不會對應用程式或者資料庫的現有設計強加任何影響。 sql寫在xml里,便於統一管理和優化。通過sql語句可以滿足操作資料庫的所有需求。

  • 解除sql與程式代碼的耦合:通過提供DAO層,將業務邏輯和數據訪問邏輯分離,使系統的設計更清晰。sql和代碼的分離,提高了可維護性。

  • 提供映射標簽,支持對象與資料庫的orm欄位關係映射。

  • 提供對象關係映射標簽,支持對象關係組建維護。

  • 提供xml標簽,支持編寫動態sql。

一個mybatis程式

1.創建一個資料庫

2.在maven項目的pom.xml文件中導入依賴文件

    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.29</version>
    </dependency>

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13.1</version>
    </dependency>

<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.9</version>
</dependency>

3.在資源文件夾下命名一個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/jdbc?useSSL=false&amp;useUnicode=true&amp;characterEncoding=utf-8"/>
                <property name="username" value="root"/>
                <property name="password" value="123123"/>
            </dataSource>
        </environment>
    </environments>
    
</configuration>

4.編寫操作資料庫要用的SQLSession對象並且封裝成一個工具類

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;

/**
 * @author panglili
 * @create 2022-07-21-14:49
 */
public class MybatisUtil {
    static SqlSessionFactory build;
    static {
        String resource="mybatis-config.xml";
        InputStream inputStream = null;
        try {
            inputStream = Resources.getResourceAsStream(resource);

            build = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

    //通過sqlSessionFactoryBuild創建拿到了工廠,由這個工廠就可以拿到sqlSession了
    //sqlSession中封裝了所有操作資料庫的代碼
    public static SqlSession getSqlSession(){
        SqlSession sqlSession = build.openSession();

        return sqlSession;
    }
}

5.與資料庫對應的實體類

package pojo;

import java.util.Date;

/**
 * @author panglili
 * @create 2022-07-21-15:01
 */
public class perple {
    private int id;
    private String name;
    private int age;
    private Date birth;

    public int getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public Date getBirth() {
        return birth;
    }

    public void setBirth(Date birth) {
        this.birth = birth;
    }

    @Override
    public String toString() {
        return "perple{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", birth=" + birth +
                '}';
    }
}

6.介面與介面的配置操作資料庫文件,儘量命名為相同

package mapper;

import pojo.perple;

import java.util.List;

/**
 * @author panglili
 * @create 2022-07-21-15:07
 */
public interface perpleMapper {

    //查詢所有信息
    List<perple> perples();

    //通過id查詢某個用戶
    perple queryById();
}
<?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="mapper.perpleMapper">

    <select id="perples" resultType="pojo.perples">
        select * from perple;
    </select>
</mapper>

7.註冊到mybatis配置文件

<mappers>
        <mapper resource="mapper/perpleMapper.xml"></mapper>
    </mappers>

8.測試

package mapper;
import org.apache.ibatis.session.SqlSession;
import pojo.perple;
import util.MybatisUtil;
import java.util.List;
/**
 * @author panglili
 * @create 2022-07-21-15:16
 */
public class perpleTest {
    public void test(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        perpleMapper mapper = sqlSession.getMapper(perpleMapper.class);
        List<perple> perples = mapper.();
        for(int i=0;i<perples.size();i++){
            System.out.println(perples.get(i));
        }

    }
}

最後可能會遇到靜態資源過濾的問題需要在pom配置文件加上處理

 <build>
    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
            </includes>
            <filtering>true</filtering>
        </resource>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
            </includes>
            <filtering>true</filtering>
        </resource>
    </resources>
</build>

完整的增刪改查

package mapper;

import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import pojo.perple;
import util.MybatisUtil;

import javax.print.attribute.standard.DateTimeAtCompleted;
import java.util.Date;
import java.util.List;

/**
 * @author panglili
 * @create 2022-07-21-15:16
 */
public class perpleTest {
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    perpleMapper mapper = sqlSession.getMapper(perpleMapper.class);

    @Test
    public void test(){
         List<perple> perples = mapper.queryAll();
        for(int i=0;i<perples.size();i++){
            System.out.println(perples.get(i));
        }
    }
    //通過id查詢
    @Test
    public void test1(){
        perple perple = mapper.queryById(1);
        System.out.println(perple);
    }

    //刪除
    @Test
    public void test2(){
        mapper.deleteById(1);
        sqlSession.commit();
    }

    //增加
    @Test
    public void test3(){

        perple perple=new perple(2,"tata",13,"2002-1");
        mapper.add(perple);
        //大坑 一定要開啟提交事務
        sqlSession.commit();
    }


    //修改
    @Test
    public void test4(){
        perple perple=new perple(2,"tata",18,"2002-1");
        mapper.update(perple);
        sqlSession.commit();
    }
}

一定要記得開啟事務!!!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 .NET在跨平臺後對於應用的部署而言,不在像.NET Framework的時候那麼單一化了,一個.NET Core應用的部署工作就可以涉及到很多知識點。 就對於windows而言,我們可以選擇使用IIS和Kestrel作為我們的Web伺服器。既可以把網站的部署用“進程內托管”方式插入IIS管道 ...
  • Linux 的應用安裝,升級和卸載 1.源碼安裝:太古老了,基本沒人用了 2.通過紅帽的包管理器安裝: 語法:rpm [參數] 軟體包名 (1)參數: i :安裝; U:升級; e:清除(卸載)軟體包; v:驗證包; h:顯示進度條; q:查詢選項; a:查詢/驗證所有包; (2)常用參數組合: - ...
  • 現象 在ubuntu上編譯內核時,apt-get source時出現如下warning: W: Download is performed unsandboxed as root as file '/var/cache/apt/archives/partial/samba-libs_2%3a4.5. ...
  • 10 | MySQL為什麼有時候會選錯索引? 使用哪個索引是由 MySQL 來確定的 可能遇到的情況:一條本來可以執行得很快的語句,卻由於 MySQL 選錯了索引,而導致執行速度變得很慢 先建一個簡單的表,表裡有 a、b 兩個欄位,並分別建上索引: CREATE TABLE `t` ( `id` i ...
  • 11 | 怎麼給字元串欄位加索引? Q:如何在郵箱這樣的欄位上建立合理的索引? 用戶表的定義: create table SUser( ID bigint unsigned primary key, email varchar(64), ... )engine=innodb; 由於要使用郵箱登錄,所 ...
  • 06 | 全局鎖和表鎖 :給表加個欄位怎麼有這麼多阻礙? Connection連接與Session會話 通俗來講,會話(Session)是通信雙⽅從開始通信到通信結束期間的⼀個上下文(Context)。這個上下文是⼀段位於伺服器端的記憶體:記錄了本次連接的客戶端機器、通過哪個應用程式、哪個用戶登錄等信 ...
  • 09 | 普通索引和唯一索引,應該怎麼選擇? 每個人都有一個唯一的身份證號,而且業務代碼已經保證了不會寫入兩個重覆的身份證號。如果市民系統需要按照身份證號查姓名,就會執行類似這樣的 SQL 語句: select name from CUser where id_card = 'xxxxxxxyyyy ...
  • 分享嘉賓:張鴻志博士 美團 演算法專家 編輯整理:廖媛媛 美的集團 出品平臺:DataFunTalk **導讀:**美團作為中國最大的線上本地生活服務平臺,連接著數億用戶和數千萬商戶,其背後蘊含著豐富的與日常生活相關的知識。美團知識圖譜團隊從2018年開始著力於圖譜構建和利用知識圖譜賦能業務,改善用戶 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...