Mybatis-Plus Mapper映射文件使用

介绍

MyBatis 的真正强大在于它的语句映射,这是它的魔力所在。由于它的异常强大,映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码。MyBatis 致力于减少使用成本,让用户能更专注于 SQL 代码。
官网中文文档:https://www.mybatis.net.cn/sqlmap-xml.html

Mapper映射文件使用

application.properties 添加配置

# mapper.xml 配置文件路径
mybatis-plus.mapper-locations=classpath:mapper/*.xml
# 配置XML映射文件中指定的实体类别名路径
mybatis-plus.type-aliases-package=cn.qvtu.web.domain

在项目mapper目录中创建Mapper文件

mapper.xml文件放在resources/mapper目录中
在这里插入图片描述

UserMapper.xml 文件

简单增删改查SQL配置,namespace对应 UserMapper.java 的包名

<?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="cn.qvtu.web.mapper.UserMapper"><select id="selectUserById" parameterType="long" resultType="User">SELECT * FROM user WHERE id = #{id}</select><insert id="insertUser" parameterType="User" >insert into user (id,name,age,email)values (#{id},#{name},#{age},#{email})</insert><update id="updateUser" parameterType="User" >update user setname = #{name},age = #{age},email = #{email}where id = #{id}</update><delete id="deleteUser" parameterType="long">delete from user where id = #{id}</delete><select id="selectUserList" parameterType="User" resultType="User">SELECT * FROM user WHERE 1=1<if test="name != null and name != ''">AND name = #{name}</if><if test="email != null and email != ''">AND email = #{email}</if><if test="age != null">AND age = #{age}</if></select></mapper>

UserMapper.java 文件

UserMapper.xml文件中 每个id名称对应UserMapper.java的方法名称

@Mapper
public interface UserMapper extends BaseMapper<User> {public User selectUserById(Long id);public void updateUser(User user);public void insertUser(User user);public void deleteUser(Long id);public List<User> selectUserList(User user);
}

IUserService 文件

定义具体业务逻辑的接口

public interface IUserService extends IService<User> {public User selectUserById(Long id);public void updateUser(User user);public void insertUser(User user);public void deleteUser(Long id);public List<User> selectUserList(User user);}

UserServiceImpl文件

实现具体业务逻辑的接口,调用UserMapper实现数据的CRUD

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper,User> implements IUserService {@Autowiredprivate UserMapper userMapper;@Overridepublic User selectUserById(Long id) {return userMapper.selectUserById(id);}@Overridepublic void updateUser(User user) {userMapper.updateUser(user);}@Overridepublic void insertUser(User user) {userMapper.insertUser(user);}@Overridepublic void deleteUser(Long id) {userMapper.deleteUser(id);}@Overridepublic List<User> selectUserList(User user) {return userMapper.selectUserList(user);}}

UserController 文件

前端访问控制器

@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate IUserService userService;@GetMapping("/select")public User select(Long id){return userService.selectUserById(id);}@GetMapping("/insert")public String insert(User user){userService.insertUser(user);return "insert SUCCESS";}@GetMapping("/update")public String update(User user){userService.updateUser(user);return "update SUCCESS";}@GetMapping("/delete")public String delete(Long id){userService.deleteUser(id);return "delete SUCCESS";}@GetMapping("/selectList")public List<User> select(User user){return userService.selectUserList(user);}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/519597.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

T01类加载机制

类加载机制 类加载运行全过程 当我们用java命令运行某个类的main函数启动程序时&#xff0c;首先需要通过类加载器把主类加载到JVM public class Math {public static final int initData 666;public static User user new User();public int compute() {int a 1;int b …

[LeetCode][239]【学习日记】滑动窗口最大值——O(n)单调队列

题目 239. 滑动窗口最大值 难度&#xff1a;困难相关标签相关企业提示 给你一个整数数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回滑动窗口中的最大值。 示例 1…

Vue中如何处理用户权限?

在前端开发中&#xff0c;处理用户权限是非常重要的一个方面。Vue作为一种流行的前端框架&#xff0c;提供了很多便捷的方式来管理用户权限。本文将介绍一些Vue中处理用户权限的方法 1. 使用路由守卫 Vue Router提供了一个功能强大的功能&#xff0c;即导航守卫&#xff08;N…

testvue-个人中心

header.vue(右上角) <template><div class="header"><!-- 折叠按钮 --><div class="collapse-btn" @click="collapseChage"><i v-if="!collapse" class="el-icon-s-fold"></i><…

使用java批量写入环境变量

环境需求 jdk版本&#xff1a;1.8 jna依赖&#xff1a; <dependency><groupId>net.java.dev.jna</groupId><artifactId>jna</artifactId><version>5.10.0</version></dependency><dependency><groupId>net.java.…

培训机构新助力:教务管理工教务管理新境界:完善流程,高效运营触手可及具

随着科技的不断进步&#xff0c;教育领域正迎来一场革命性的变革。乔拓云教育系统&#xff0c;作为这场变革的引领者&#xff0c;正以其卓越的功能和高效的解决方案&#xff0c;为培训机构带来前所未有的教务管理新篇章。 一、高效排课&#xff0c;让教务管理更轻松 乔拓云教育…

模型部署——rknn-toolkit-lite2部署RKNN模型到开发板上(python版)

在RKNN模型部署前&#xff0c;需要注意以下几点&#xff1a; &#xff08;1&#xff09;硬件平台兼容性: 确保你的开发板与 RKNN Toolkit Lite2 兼容。目前&#xff0c;RKNN Toolkit Lite2 支持 Rockchip RK3566、RK3588、RK3399 等平台。 确认开发板的 NPU 型号和版本与 RKNN…

1.BOM-获取元素(获取元素、修改属性)

web Api基本认知 作用&#xff1a;通过JS去操作html页面和浏览器(实现浏览器中的某些功能) 分类&#xff1a; DOM(网页)&#xff1a;Document Object Model(文档对象模型) BOM(浏览器)&#xff1a;Borwser Object Model(浏览器对象模型) DOM DOM树 将网页中标签的关系以树状…

数字孪生10个技术栈:数据处理的六步骤,以获得可靠数据。

一、什么是数据处理 在数字孪生中&#xff0c;数据处理是指对采集到的实时或历史数据进行整理、清洗、分析和转化的过程。数据处理是数字孪生的基础&#xff0c;它将原始数据转化为有意义的信息&#xff0c;用于模型构建、仿真和决策支持。 数据处理是为了提高数据质量、整合数…

Frida-Hook-Native层操作大全

前期准备 使用 jadx 进行逆向工程的基础知识。能够理解 Java 代码。能够编写简短的 JavaScript 代码片段。熟悉 adb。已 root 的设备。对 x86/ARM64 汇编和逆向工程有基础了解。 1、Hook Native层中调用的函数并且读取传入的参数 对于Native层的函数Hook&#xff0c;我们使用…

计算阶梯数 Python

题目描述 爱因斯坦曾出过这样一道有趣的数学题&#xff1a; 有一个长阶梯&#xff0c; 若每步上2阶&#xff0c;最后剩1阶&#xff1b; 若每步上3阶&#xff0c;最后剩2阶&#xff1b; 若每步上5阶&#xff0c;最后剩4阶&#xff1b; 若每步上6阶&#xff0c;最后剩5阶&#xf…

MES+APS难度地狱级,搞定它就是劫后余生呀。

一、什么是MES和APS MES&#xff08;Manufacturing Execution System&#xff09;和APS&#xff08;Advanced Planning and Scheduling&#xff09;是两种在制造业中常用的软件系统&#xff0c;用于优化生产过程和提高生产效率。 MES是一种用于管理和监控制造过程的系统。它与…