二酿傍、搭建MyBatis采用xml方式烙懦,驗(yàn)證CRUD(增刪改查操作)

image.png

@[toc]

二、搭建MyBatis采用xml方式赤炒,驗(yàn)證CRUD(增刪改查操作)

2.1 開發(fā)環(huán)境

IDE:idea 2021.1
構(gòu)建工具:maven 3.8.4
MySQL版本:MySQL 5.7.40
MyBatis版本:MyBatis 3.5.7

數(shù)據(jù)庫表:

image.png

2.2 創(chuàng)建maven工程

項(xiàng)目初始目錄

image.png

引入依賴

<dependencies>
    <!-- Mybatis核心 -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.7</version>
    </dependency>
    <!-- junit測(cè)試 -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13</version>
        <scope>test</scope>
    </dependency>
    <!-- MySQL驅(qū)動(dòng) -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.31</version>
    </dependency>
    <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.22</version>
        </dependency>
</dependencies>

2.3 創(chuàng)建User實(shí)體

com/mybatis/entity/User.java

package com.mybatis.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

/**
 * @Author 211145187
 * @Date 2023/4/17 22:33
 **/
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class User {
    //id
    private Integer id;
    //用戶名稱
    private String username;
    //用戶密碼
    private String password;
    //用戶手機(jī)號(hào)碼
    private String mobile;
    
    public User(String username, String password, String mobile, Integer gender)    {
        this.username = username;
        this.password = password;
        this.mobile = mobile;
        this.gender = gender;
    }

    public User(String username, Integer gender) {
        this.username = username;
        this.gender = gender;
    }
}

2.4 創(chuàng)建MyBatis的核心配置文件

  • 習(xí)慣上命名為mybatis-config.xml莺褒,這個(gè)文件名僅僅只是建議,并非強(qiáng)制要求遵岩。將來整合Spring

之后,這個(gè)配置文件可以省略舍哄,所以大家操作時(shí)可以直接復(fù)制誊锭、粘貼。

  • 核心配置文件主要用于配置連接數(shù)據(jù)庫的環(huán)境以及MyBatis的全局配置信息炉旷。

  • 核心配置文件存放的位置是src/main/resources目錄下

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>
    <!--設(shè)置連接數(shù)據(jù)庫的環(huán)境-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://192.168.31.20:3306/litemall"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>

    <!--引入映射文件-->
    <mappers>
        <mapper resource="mapper/UserMapper.xml"/>
    </mappers>
</configuration>

2.5 創(chuàng)建mapper接口

MyBatis中的mapper接口相當(dāng)于以前的dao饥追。但是區(qū)別在于罐盔,mapper僅僅是接口,我們不需要

提供實(shí)現(xiàn)類捏顺。

package com.mybatis.mapper;

public interface UserMapper {
    /**
     * MyBatis面向接口編程的兩個(gè)一致:
     * 1纬黎、映射文件的namespace要和mapper接口的全類名保持一致
     * 2、映射文件中SQL語句的id要和mapper接口中的方法名一致
     *
     * 表--實(shí)體類--mapper接口--映射文件
     */

    /**
     * 添加用戶信息
     */
    int insertUser();

    /**
     * 修改用戶信息
     */
    void updateUser();

    /**
     * 刪除用戶信息
     */
    void deleteUser();
    
    /**
     * 根據(jù)id查詢用戶信息
     */
    User getUserById();

    /**
     * 查詢所有的用戶信息
     */
    List<User> getAllUser();
}

2.6 創(chuàng)建MyBatis的映射文件

相關(guān)概念ORMObject Relationship Mapping)對(duì)象關(guān)系映射本今。

對(duì)象:Java的實(shí)體類對(duì)象

關(guān)系:關(guān)系型數(shù)據(jù)庫

映射:二者之間的對(duì)應(yīng)關(guān)系

Java概念 數(shù)據(jù)庫概念
屬性 字段/列
對(duì)象 記錄/行
  1. 映射文件的命名規(guī)則:
    表所對(duì)應(yīng)的實(shí)體類的類名+Mapper.xml
    例如:表litemall_user,映射的實(shí)體類為User挪凑,所對(duì)應(yīng)的映射文件為UserMapper.xml
    因此一個(gè)映射文件對(duì)應(yīng)一個(gè)實(shí)體類,對(duì)應(yīng)一張表的操作
    MyBatis映射文件用于編寫SQL搞旭,訪問以及操作表中的數(shù)據(jù)
    MyBatis映射文件存放的位置是src/main/resources/mappers目錄下
  2. MyBatis中可以面向接口操作數(shù)據(jù)菇绵,要保證兩個(gè)一致:
    a>mapper接口的全類名和映射文件的命名空間(namespace)保持一致
    b>mapper接口中方法的方法名和映射文件中編寫SQL的標(biāo)簽的id屬性保持一致
<?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.mybatis.mapper.UserMapper">

    <insert id="insertUser">
        insert into litemall.litemall_user(id, username, password, mobile) values(null,'張三','123456','15197289663')
    </insert>

    <update id="updateUser">
        update litemall.litemall_user set username = '張三' where id = 4
    </update>

    <delete id="deleteUser">
        delete from litemall.litemall_user where id = 2
    </delete>
    
    <!--
        查詢功能的標(biāo)簽必須設(shè)置resultType或resultMap
        resultType:設(shè)置默認(rèn)的映射關(guān)系
        resultMap:設(shè)置自定義的映射關(guān)系
    -->
    <select id="getUserById" resultType="com.mybatis.entity.User">
        select * from litemall.litemall_user where id = 3
    </select>

    <select id="getAllUser" resultType="com.mybatis.entity.User">
        select * from litemall.litemall_user
    </select>
</mapper>

2.7配置日志打印

添加log4j依賴

<!-- log4j日志 -->
<dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
</dependency>

創(chuàng)建log4j.xml配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
        <param name="Encoding" value="UTF-8" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n" />
        </layout>
    </appender>
    <logger name="java.sql">
        <level value="debug" />
    </logger>
    <logger name="org.apache.ibatis">
        <level value="info" />
    </logger>
    <root>
        <level value="debug" />
        <appender-ref ref="STDOUT" />
    </root>
</log4j:configuration>

2.8 通過junit測(cè)試功能

package com.mybatis;

import com.mybatis.mapper.UserMapper;
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;

/**
 * @Author 211145187
 * @Date 2023/4/17 22:56
 **/
public class MyBatisTest {
    /**
     * SqlSession默認(rèn)不自動(dòng)提交事務(wù)脸甘,若需要自動(dòng)提交事務(wù)
     * 可以使用SqlSessionFactory.openSession(true);
     */

    //測(cè)試插入
    @Test
    public void testMyBatisInsert() throws IOException {
        //加載核心配置文件
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        //獲取SqlSessionFactoryBuilder對(duì)象
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        //通過核心配置文件所對(duì)應(yīng)的字節(jié)輸入流創(chuàng)建工廠類SqlSessionFactory,生產(chǎn)SqlSession對(duì)象
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
        //創(chuàng)建SqlSession對(duì)象钝的,此時(shí)通過SqlSession對(duì)象所操作的sql都會(huì)自動(dòng)提交铆遭,默認(rèn)openSession中形參為false
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        //通過代理模式創(chuàng)建UserMapper接口的代理實(shí)現(xiàn)類對(duì)象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //測(cè)試功能
        int result = mapper.insertUser();
        //提交事務(wù)
        //sqlSession.commit();
        System.out.println("result:"+result);
    }

    //測(cè)試【修改、刪除枚荣、單條查詢、集合查詢】
    @Test
    public void testMyBatisCRUD() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //更新
//        mapper.updateUser();
        //刪除
//        mapper.deleteUser();
        //單條查詢
//        User user = mapper.getUserById();
//        System.out.println(user);
        //集合查詢
//        List<User> userList = mapper.getAllUser();
//        userList.forEach(user -> System.out.println(user));
    }
}

SqlSession:代表Java程序和數(shù)據(jù)庫之間的會(huì)話衙伶。(HttpSession是Java程序和瀏覽器之間的
會(huì)話)

SqlSessionFactory:是“生產(chǎn)”SqlSession的“工廠”害碾。

工廠模式:如果創(chuàng)建某一個(gè)對(duì)象,使用的過程基本固定慌随,那么我們就可以把創(chuàng)建這個(gè)對(duì)象的
相關(guān)代碼封裝到一個(gè)“工廠類”中,以后都使用這個(gè)工廠類來“生產(chǎn)”我們需要的對(duì)象丸逸。

本人其他相關(guān)文章鏈接

1.一剃袍、MyBatis簡(jiǎn)介:MyBatis歷史、MyBatis特性民效、和其它持久化層技術(shù)對(duì)比、Mybatis下載依賴包流程
2.二埋同、搭建MyBatis采用xml方式棵红,驗(yàn)證CRUD(增刪改查操作)
3.三逆甜、MyBatis核心配置文件詳解
4.四交煞、MyBatis獲取參數(shù)值的兩種方式(重點(diǎn))
5.五素征、MyBatis的增刪改查模板(參數(shù)形式包括:String御毅、對(duì)象、集合凤粗、數(shù)組、Map)
6.六嫌拣、MyBatis特殊的SQL:模糊查詢呆躲、動(dòng)態(tài)設(shè)置表名、校驗(yàn)名稱唯一性
7.七歼秽、MyBatis自定義映射resultMap
8.八、(了解即可)MyBatis懶加載(或者叫延遲加載)
9.九箩祥、MyBatis動(dòng)態(tài)SQL
10.十肆氓、MyBatis的緩存
11.十一、MyBatis的逆向工程
12.十二谢揪、MyBatis分頁插件

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末捐凭,一起剝皮案震驚了整個(gè)濱河市凳鬓,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌垦梆,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件托猩,死亡現(xiàn)場(chǎng)離奇詭異辽慕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)公浪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門船侧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人勺爱,你說我怎么就攤上這事∥篮担” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵顾翼,是天一觀的道長(zhǎng)奈泪。 經(jīng)常有香客問我,道長(zhǎng)拜姿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任蕊肥,我火速辦了婚禮蛤肌,結(jié)果婚禮上批狱,老公的妹妹穿的比我還像新娘展东。我一直安慰自己,他們只是感情好盐肃,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布恼蓬。 她就那樣靜靜地躺著,像睡著了一般处硬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上疮方,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天,我揣著相機(jī)與錄音惫谤,去河邊找鬼。 笑死许蓖,一個(gè)胖子當(dāng)著我的面吹牛自阱,可吹牛的內(nèi)容都是我干的动壤。 我是一名探鬼主播阁簸,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼启妹,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起匈棘,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤逃默,失蹤者是張志新(化名)和其女友劉穎完域,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乌妙,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年镐依,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡带兜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出喧兄,到底是詐尸還是另有隱情浑彰,我是刑警寧澤郭变,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布薄风,位于F島的核電站,受9級(jí)特大地震影響撇他,放射性物質(zhì)發(fā)生泄漏困肩。R本人自食惡果不足惜锌畸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一潭枣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧篡九,春花似錦、人聲如沸窜司。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至捅位,卻和暖如春艇搀,著一層夾襖步出監(jiān)牢的瞬間焰雕,已是汗流浹背矩屁。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留烁峭,地道東北人则剃。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像己肮,于是被迫代替她去往敵國和親谎僻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艘绍,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容