MyBatis-Plus是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,使用MyBatis-Plus时,不会影响原来Mybatis方式的使用。

SpringBoot+MyBatis-Plus环境搭建

SQL脚本:

CREATE TABLE `tb_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`real_name` varchar(20) DEFAULT NULL,
`email` varchar(50) DEFAULT NULL,
`phone` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO tb_user (real_name,email,phone) VALUES ('小花','cf1@qq.com','18711111111');
INSERT INTO tb_user (real_name,email,phone) VALUES ('小菊','cf2@qq.com','18322222222');
INSERT INTO tb_user (real_name,email,phone) VALUES ('小熊','cf3@qq.com','18133333333');
INSERT INTO tb_user (real_name,email,phone) VALUES ('小虎','cf4@qq.com','18344444444');
INSERT INTO tb_user (real_name,email,phone) VALUES ('小猪','cf5@qq.com','18723232323');

添加依赖如下(不需要额外添加Mybatis的依赖):

<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.3.1.tmp</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
</dependencies>

application.yml:

spring:
datasource:
url: jdbc:mysql://localhost/plusdb?useUnicode=true&characterEncoding=UTF-8
username: root
password: 123456
driver-class-name: com.mysql.jdbc.Driver #在控制台打印SQL语句,com.cf.mpdm.mapper为存放mapper接口的包名
logging:
level:
com.cf.mpdm.mapper: debug

主程序类:

package com.cf.mpdm;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication; //指定扫描mapper接口的包路径
@MapperScan("com.cf.mpdm.mapper")
@SpringBootApplication
public class MpdmApplication { public static void main(String[] args) {
SpringApplication.run(MpdmApplication.class, args);
} }

UserMapper接口:

package com.cf.mpdm.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.cf.mpdm.entity.User; public interface UserMapper extends BaseMapper<User> {
}

UserMapper接口需要继承BaseMapper接口,并且指定泛型为表对应的实体类。

实体类User:

package com.cf.mpdm.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName; //表名tb_user带tb_前缀,和实体类类名User不匹配,所以需要使用@TableName指定表名
@TableName("tb_user")
public class User { //指定主键生成策略为自动增长
@TableId(type = IdType.AUTO)
private Integer id; private String realName; private String email; private String phone; //get/set ...
}

MyBatis-Plus默认使用下划线命名到驼峰命名的映射规则来处理表和实体类类名以及表的列名和实体类字段的映射。当默认规则不适用时,则需要通过额外的配置来处理映射,如可以使用注解@TableName来指定表名,使用@TableId和@TableField来指定主键列和非主键列的列名。

@TableId还可以指定主键的生成策略,默认生成策略为NONE,表示无状态,未设置主键类型。其他策略详见IdType

当多数表具有相同的前缀或者相同的主键生成策略时,可以使用全局配置指定表前缀和主键策略,而无需一个个手动添加注解,当然少数特殊的还是可以通过注解的方式来指定,application.yml:

mybatis-plus:
global-config:
db-config:
# 指定主键生成策略为自动增长
idType: AUTO
# 指定表前缀
tablePrefix: tb_

基本的CRUD操作

package com.cf.mpdm;

import com.cf.mpdm.entity.User;
import com.cf.mpdm.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.HashMap;
import java.util.List;
import java.util.Map; @SpringBootTest
class MpdmApplicationTests {
@Autowired
private UserMapper userMapper; @Test
public void testInsert(){
//INSERT INTO tb_user ( real_name, email, phone ) VALUES ( ?, ?, ? )
User user = new User();
user.setRealName("小兰");
user.setEmail("xiaolan@qq.com");
user.setPhone("18700000000");
userMapper.insert(user); //插入成功时,默认会将主键的值回写到实体类中去
System.out.println(user.getId());
} @Test
public void testDelete(){
//根据主键ID删除记录
//DELETE FROM tb_user WHERE id=?
userMapper.deleteById(6); //根据id列表批量删除记录
//DELETE FROM tb_user WHERE id IN ( ? , ? )
/*List<Integer> idList = new ArrayList<>();
idList.add(12);
idList.add(13);
userMapper.deleteBatchIds(idList);*/ //根据条件来删除记录,如根据real_name来删除记录,columnMap的Key必须为表中的字段名,而不是实体类中的字段名。
//DELETE FROM tb_user WHERE real_name = ?
/*Map<String, Object> columnMap = new HashMap<>();
columnMap.put("real_name", "小花");
userMapper.deleteByMap(columnMap);*/
} @Test
public void testUpdate(){
//根据主键id更新记录
//UPDATE tb_user SET real_name=? WHERE id=?
User user = new User();
user.setId(2);
user.setRealName("欧皓辰");
userMapper.updateById(user);
} @Test
public void testSelect(){
//根据主键id查询记录
//SELECT id,real_name,email,phone FROM tb_user WHERE id=?
/*User user = userMapper.selectById(3);
System.out.println(user.getRealName());*/ //根据id列表查询对应记录
//SELECT id,real_name,email,phone FROM tb_user WHERE id IN ( ? , ? )
/*List<Integer> idList = new ArrayList<>();
idList.add(3);
idList.add(4);
List<User> userList = userMapper.selectBatchIds(idList);
System.out.println(userList.size());*/ //根据条件来查询对应记录
//SELECT id,real_name,email,phone FROM tb_user WHERE real_name = ?
Map<String, Object> columnMap = new HashMap<>();
columnMap.put("real_name", "小兰");
List<User> userList = userMapper.selectByMap(columnMap);
System.out.println(userList.size());
}
}

关于使用mapper.xml的一些配置

mybatis-plus:
#指定Mapper所对应的XML文件位置
mapperLocations: classpath:mapper/*.xml
#指定别名包扫描路径,通过该属性可以给包中的类注册别名,注册后在 Mapper 对应的 XML 文件中可以直接使用类名,而不用使用全限定的类名
typeAliasesPackage: com.cf.mpdm.entity

MyBatis-Plus学习笔记(1):环境搭建以及基本的CRUD操作的更多相关文章

  1. Android Studio 学习笔记(一)环境搭建、文件目录等相关说明

    Android Studio 学习笔记(一)环境搭建.文件目录等相关说明 引入 对APP开发而言,Android和iOS是两大主流开发平台,其中区别在于 Android用java语言,用Android ...

  2. Mybatis学习笔记之---环境搭建与入门

    Mybatis环境搭建与入门 (一)环境搭建 (1)第一步:创建maven工程并导入jar包 <dependencies> <dependency> <groupId&g ...

  3. 我的Java学习笔记 -开发环境搭建

    开始学习Java~ 一.Java简介 Java编程语言是一种简单.面向对象.分布式.解释型.健壮安全.与系统无关.可移植.高性能.多线程和动态的语言. Java分为三个体系: JavaSE(J2SE) ...

  4. Django学习笔记 开发环境搭建

    为什么使用django?1.支持快速开发:用python开发:数据库ORM系统,并不需要我们手动地构造SQL语句,而是用python的对象访问数据库,能够提升开发效率.2.大量内置应用:后台管理系统a ...

  5. cocos2d-x lua 学习笔记(1) -- 环境搭建

    Cocos2d-x 3.0以上版本的环境搭建和之前的Cocos2d-x 2.0 版差异较大的,同时从Cocos2d-x 3.0项目打包成apk安卓应用文件,搭建安卓环境的步骤有点繁琐,但搭建一次之后, ...

  6. go 学习笔记之环境搭建

    千里之行始于足下,开始 Go 语言学习之旅前,首先要搭建好本地开发环境,然后就可以放心大胆瞎折腾了. Go 的环境安装和其他语言安装没什么特别注意之处,下载安装包下一步下一步直到完成,可能唯一需要注意 ...

  7. SpringData JPA的学习笔记之环境搭建

    一.环境搭建 1.加入jar包   spring jar+jpa jar +springData jar >>SpringData jar包     2.配置applicationCont ...

  8. 前端框架vue学习笔记:环境搭建

    兼容性 不兼容IE8以下 Vue Devtools 能够更好的对界面进行审查和调试 环境搭建 1.nodejs(新版本的集成了npm)[npm是node包管理 node package manager ...

  9. Web安全测试学习笔记 - vulhub环境搭建

    Vulhub和DVWA一样,也是开源漏洞靶场,地址:https://github.com/vulhub/vulhub 环境搭建过程如下: 1. 下载和安装Ubuntu 16.04镜像,镜像地址:htt ...

随机推荐

  1. 洛谷——P1012拼数字符串操作(拼接排序)

    #include<bits/stdc++.h> using namespace std; bool cmp(const string &a,const string &b) ...

  2. RobotFramework+Appium 升级Appium v1.10.0后,执行click element时报错:InvalidSelectorException: Message: Locator Strategy 'css selector' is not supported for this session,解决办法

    报错信息如下: debug] [35m[XCUITest][39m Connection to WDA timed out[debug] [35m[XCUITest][39m Connection t ...

  3. seek方法补充

    seek 默认模式是从文件的开始移动光标,一共有0.1.2三种模式 f=open('seek.txt','r',encoding='utf-8') print(f.tell()) f.seek(10, ...

  4. Django学习小记1-安装配置

    Django是一个开放源代码的Web应用框架,由Python写成. python 中的web框架有许多例如:Django.Tornado.Flask..而Django相较与其他WEB框架其优势为:大而 ...

  5. 洛谷$P2150\ [NOI2015]$寿司晚宴 $dp$

    正解:$dp$ 解题报告: 传送门$QwQ$. 遇事不决写$dp$($bushi$.讲道理这题一看就感觉除了$dp$也没啥很好的算法能做了,于是考虑$dp$呗 先看部分分?$30pts$发现质因数个数 ...

  6. 洛谷$P$3066 逃跑的$BarnRunning\ Away\ From…$ $[USACO12DEC]$ 主席树

    正解:主席树 解题报告: 传送门! 1551做$dp$实在是做不下去了,,,于是来水点儿别的题$QAQ$ 然后这题,挺纸老虎的我$jio$得,,,看起来很难的样子然后仔细想下之后发现依然是个板子呢,, ...

  7. 洛谷$P$3327 约数个数和 $[SDOI2015]$ 莫比乌斯反演

    正解:莫比乌斯反演 解题报告: 传送门! 先考虑证明一个结论,$d_{i\cdot j}=\sum_{p|i}\sum_{q|j}[gcd(p,q)==1]$ 看起来就很对的样子,但还是证下趴$QwQ ...

  8. 跌宕起伏的java帝国史,剖析谷歌甲骨文长达8年的版权战争

    这篇博文是我在B站上发的一个科普java的视频文案整理,本来发过一次了,但是有几种不严谨的地方只能删掉重新发了一下,内容如标题,感兴趣的码农朋友可以观看视频的版本,欢迎提提意见啥的,感谢~https: ...

  9. 小小知识点(二十)利用MATLAB计算定积分

    一重定积分 1. Z = trapz(X,Y,dim) 梯形数值积分,通过已知参数x,y按dim维使用梯形公式进行积分 %举例说明1 clc clear all % int(sin(x),0,pi) ...

  10. Python for Data Analysis 学习心得(四) - 数据清洗、接合

    一.文字处理 之前在练习爬虫时,常常爬了一堆乱七八糟的字符下来,当时就有找网络上一些清洗数据的方式,这边pandas也有提供一些,可以参考使用看看.下面为两个比较常见的指令,往往会搭配使用. spli ...