MyBatis --- 常用注解

目录

前言

[1. @Mapper](#1. @Mapper)

[2. @Select](#2. @Select)

[3. @Insert](#3. @Insert)

[4. @Update](#4. @Update)

[5. @Delete](#5. @Delete)

[6. @Results](#6. @Results)

注意事项:


前言

MyBatis是一款强大的持久层框架,通过注解的方式,可以更便捷地进行数据库操作。本文将介绍MyBatis中常用的注解以及在使用这些注解时需要注意的事项。

1. @Mapper

在MyBatis中,使用 @Mapper注解可以将一个Java接口标识为MyBatis的映射器(Mapper),告诉MyBatis这个接口是用于执行SQL语句的。

java 复制代码
@Mapper
public interface UserMapper {
    
}

2. @Select

@Select注解用于配置查询操作的SQL语句,可以在接口方法上使用,也可以在接口内部定义常量。

java 复制代码
@Select("SELECT * FROM users WHERE id = #{id}")
User getUserById(@Param("id") Long id);

3. @Insert

@Insert注解用于配置插入操作的SQL语句。

java 复制代码
@Insert("INSERT INTO users (name, age) VALUES (#{name}, #{age})")
void insertUser(User user);

4. @Update

@Update注解用于配置更新操作的SQL语句。

java 复制代码
@Update("UPDATE users SET name = #{name} WHERE id = #{id}")
void updateUser(User user);

5. @Delete

@Delete注解用于配置删除操作的SQL语句。

java 复制代码
@Delete("DELETE FROM users WHERE id = #{id}")
void deleteUserById(@Param("id") Long id);

6. @Results

@Results注解用于配置结果映射,将数据库查询的结果映射到Java对象中。

java 复制代码
@Results({
    @Result(property = "id", column = "user_id"),
    @Result(property = "name", column = "user_name")
})
@Select("SELECT user_id, user_name FROM users WHERE id = #{id}")
User getUserById(@Param("id") Long id);

注意事项:

1. 命名参数与注解参数名一致: MyBatis通过参数名来匹配SQL语句中的占位符,确保注解中的参数名与SQL语句中的参数名一致。

2. 参数注解: 在方法参数上使用 @Param注解,用于指定SQL语句中的参数名。

java 复制代码
@Select("SELECT * FROM users WHERE name = #{name} AND age = #{age}")
User getUserByNameAndAge(@Param("name") String name, @Param("age") int age);

3. 动态SQL: MyBatis支持使用<if>, <choose>, <when>, <otherwise>等标签进行动态SQL的构建,可以根据不同条件动态拼接SQL语句。

**4. 使用#{}和{}的区别:** `#{}`会将参数值以占位符的形式传递给SQL,会进行预编译,防止SQL注入。`{}`则直接将参数值嵌入到SQL语句中,慎用避免SQL注入。

相关推荐
zwz宝宝1 分钟前
26年大三下,优极限实训项目
java·spring·maven
码农研究僧5 分钟前
@JsonSerialize(using = ToStringSerializer.class) 为什么能解决前后端 Long 精度丢失问题
java·注解·jsonserialize
YOU OU23 分钟前
SpringBoot 统一功能处理
java·spring boot·后端
用户2986985301427 分钟前
Java 实现 Word 文档变量:添加与修改操作详解
java·后端
MaCa .BaKa28 分钟前
53-智慧工地人员考勤与工时管理系统
java·spring boot·mysql·tomcat·vue·maven
fengxin_rou34 分钟前
【SpringBoot 个人资料模块实战】:PATCH 局部更新 + 正则校验 + CORS 跨域全解析
java·spring boot·后端
秋浦千山河35 分钟前
坚持看完这套 JDK 源码系列,彻底摆脱 CRUD 开发|专题:java.lang.String 源码解读
java
CadeCode37 分钟前
SpringBoot 代码风格推荐
java·spring boot·代码规范
海兰39 分钟前
【应用程序】基于 Spring Boot + Spring AI的虚拟宠物Web 应用(一)
人工智能·spring boot·spring
東雪木41 分钟前
异常体系、IO 与 NIO 专属复习笔记
java·笔记·学习·nio·java面试