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注入。

相关推荐
c++之路18 分钟前
C++20概述
java·开发语言·c++20
Championship.23.2422 分钟前
Linux Top 命令族深度解析与实战指南
java·linux·服务器·top·linux调试
橘子海全栈攻城狮37 分钟前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
逻辑驱动的ken43 分钟前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
冷雨夜中漫步1 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
直奔標竿1 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
one_love_zfl2 小时前
java面试-微服务组件篇
java·微服务·面试
一只大袋鼠2 小时前
Java进阶:CGLIB动态代理解析
java·开发语言
环流_2 小时前
HTTP 协议的基本格式
java·网络协议·http
爱滑雪的码农2 小时前
Java基础十三:Java中的继承、重写(Override)与重载(Overload)详解
java·开发语言