二 mybatis-plus 入門案例

1鞋诗、準(zhǔn)備開發(fā)環(huán)境

Idea:idea 2019.2
JDK:JDK8+
構(gòu)建工具:maven 3.6.1
MySQL版本:MySQL 5.7
Spring Boot:2.6.3
MyBatis-Plus:3.5.1

2咕幻、創(chuàng)建數(shù)據(jù)庫及表

(1)創(chuàng)建表

CREATE DATABASE `mybatis_plus`;
use `mybatis_plus`;
DROP TABLE IF EXISTS user;
CREATE TABLE `user` ( 
  `id` bigint(20) NOT NULL COMMENT '主鍵ID', 
  `name` varchar(30) DEFAULT NULL COMMENT '姓名', 
  `age` int(11) DEFAULT NULL COMMENT '年齡', 
  `email` varchar(50) DEFAULT NULL COMMENT '郵箱', 
  PRIMARY KEY (`id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

(2)添加數(shù)據(jù)

DELETE FROM user;
INSERT INTO user (id, name, age, email) VALUES 
(1, 'Jone', 18, 'test1@baomidou.com'), 
(2, 'Jack', 20, 'test2@baomidou.com'), 
(3, 'Tom', 28, 'test3@baomidou.com'), 
(4, 'Sandy', 21, 'test4@baomidou.com'), 
(5, 'Billie', 24, 'test5@baomidou.com');

3雳旅、創(chuàng)建Spring Boot工程

(1)初始化工程
使用 Spring Initializr 快速初始化一個 Spring Boot 工程


image.png

image.png

image.png

(2)引入依賴

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.6.3</version>
        <relativePath/>
    </parent>

    <groupId>com.xilc</groupId>
    <artifactId>mybatis-plus-demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>

    <name>mybatis-plus-demo</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.1</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

(3)idea中安裝lombok插件


image.png

4、配置application.yml

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.1.30:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
    username: root
    password: root

注意:

1煌集、驅(qū)動類driver-class-name
Spring Boot 2.0(內(nèi)置jdbc5驅(qū)動)悦屏,驅(qū)動類使用 com.mysql.jdbc.Driver
Spring Boot 2.1及以上(內(nèi)置jdbc8驅(qū)動)严肪,驅(qū)動類使用 com.mysql.cj.jdbc.Driver
否則運行時候會有 WARN 信息

2、連接地址url
MySQL5.7版本的url:
jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
MySQL8.0版本的url:
jdbc:mysql://localhost:3306/mybatis_plus?
serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false
否則運行測試用例報告如下錯誤:
java.sql.SQLException: The server time zone value '?D1ú±ê×?ê±??' is unrecognized or represents more

5衩藤、創(chuàng)建啟動類

在Spring Boot啟動類中添加@MapperScan注解项秉,掃描mapper包

@SpringBootApplication
@MapperScan("com.xilc.mybatisplus.mapper")
public class MybatisPlusApp {
    public static void main(String[] args) {
        SpringApplication.run(MybatisPlusApp.class, args);
    }
}

6、添加實體類

@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

7慷彤、添加mapper

BaseMapper是MyBatis-Plus提供的模板mapper娄蔼,其中包含了基本的CRUD方法,泛型為操作的實體類型

public interface UserMapper extends BaseMapper<User> {
    
}

8底哗、測試

@SpringBootTest
class MybatisPlusTests {

    @Autowired
    UserMapper userMapper;
    @Test
    void testList() {
        List<User> list = userMapper.selectList(null);
        list.forEach(System.out::println);
    }
}

測試結(jié)果:

User(id=1, name=Jone, age=18, email=test1@baomidou.com)
User(id=2, name=Jack, age=20, email=test2@baomidou.com)
User(id=3, name=Tom, age=28, email=test3@baomidou.com)
User(id=4, name=Sandy, age=21, email=test4@baomidou.com)
User(id=5, name=Billie, age=24, email=test5@baomidou.com)

9岁诉、添加日志

在application.yml中配置日志輸出

mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

控制臺打印效果:

==>  Preparing: SELECT id,name,age,email FROM user
==> Parameters: 
<==    Columns: id, name, age, email
<==        Row: 1, Jone, 18, test1@baomidou.com
<==        Row: 2, Jack, 20, test2@baomidou.com
<==        Row: 3, Tom, 28, test3@baomidou.com
<==        Row: 4, Sandy, 21, test4@baomidou.com
<==        Row: 5, Billie, 24, test5@baomidou.com
<==      Total: 5
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市跋选,隨后出現(xiàn)的幾起案子涕癣,更是在濱河造成了極大的恐慌,老刑警劉巖前标,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坠韩,死亡現(xiàn)場離奇詭異,居然都是意外死亡炼列,警方通過查閱死者的電腦和手機只搁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俭尖,“玉大人氢惋,你說我怎么就攤上這事』纾” “怎么了焰望?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長已亥。 經(jīng)常有香客問我熊赖,道長,這世上最難降的妖魔是什么虑椎? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任震鹉,我火速辦了婚禮的妖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘足陨。我一直安慰自己嫂粟,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布墨缘。 她就那樣靜靜地躺著星虹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪镊讼。 梳的紋絲不亂的頭發(fā)上宽涌,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天,我揣著相機與錄音蝶棋,去河邊找鬼卸亮。 笑死,一個胖子當(dāng)著我的面吹牛玩裙,可吹牛的內(nèi)容都是我干的兼贸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼吃溅,長吁一口氣:“原來是場噩夢啊……” “哼溶诞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起决侈,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤螺垢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后赖歌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體枉圃,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年庐冯,在試婚紗的時候發(fā)現(xiàn)自己被綠了孽亲。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,739評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡肄扎,死狀恐怖墨林,靈堂內(nèi)的尸體忽然破棺而出赁酝,到底是詐尸還是另有隱情犯祠,我是刑警寧澤,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布酌呆,位于F島的核電站衡载,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏隙袁。R本人自食惡果不足惜痰娱,卻給世界環(huán)境...
    茶點故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一弃榨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧梨睁,春花似錦鲸睛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至遍坟,卻和暖如春拳亿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背愿伴。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工肺魁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人隔节。 一個月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓鹅经,卻偏偏與公主長得像,于是被迫代替她去往敵國和親怎诫。 傳聞我的和親對象是個殘疾皇子瞬雹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,647評論 2 354

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