MyBatis(十一) 注解详解

简介: MyBatis常用注解详解介绍

一. 注解开发

  • 注解是用于描述代码的代码. 例如:
    @Test(用于描述方法进行 junit 测试), @Override(用于描述方法的重写), @Param(用于描述属性的名称)
  • 注解的使用风格: @xxx(属性), 使用前必须先导包
  • 使用注解一般用于简化配置文件. 但是, 注解有时候也不是很友好(有时候反而更麻烦), 例如动态 SQL.
  • 关于注解的属性
    属性的设定方式是: 属性名=属性值
  • 关于属性值的类型

基本类型和 String, 可以直接使用双引号的形式
数组类型, name={值 1, 值 2, ...}; 如果数组元素只有一个, 可以省略大括号
对象类型, name=@对象名(属性)
如果属性是该注解的默认属性, 而且该注解只配置这一个属性, 可以将属性名省略

  • 注解和配置文件可以配合使用

二. MyBatis 中常用的注解---CRUD 注解

@Select: 类似于 <select>
@Insert: 类似于 <insert>
@Update: 类似于 <update>
@Delete: 类似于 <delete>
package cn.bjsxt.mapper;

import java.util.List;

import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

import cn.bjsxt.pojo.Student;
/**
 * 通过注解,直接胜略配置文件的书写
 * 查询所有学生
 * @author chy
 *
 */
public interface StudentMapper {
    
    //@Select(value={"select * from t_student"})//一条语句时,可以省略大括号
    //@Select(value="select * from t_student")//使用默认值是,可以省略value
    @Select("select * from t_student")
    List<Student> selAll();
    
    @Insert("insert into t_student values (#{id},#{name},#{age},#{gender},#{cid})")
    int insStu(Student student);
    //0、1代表参数插入的顺序,先传入的是id,故为0,。后传入的是age,故为1
    
    @Update("update t_student set age=#{1} where id=#{0}")
    int updStu(int id,int age);
    @Delete("delete from t_student where id=#{0}")
    int delStu(int id);
}

三. MyBatis 中常用的注解---其他注解

@Results: 类似于 <resultMap>
@Result: 类似于 <resultMap>的子标签
@One: 类似于 <association>
@Many: 类似于 <collection>
package cn.bjsxt.mapper;

import java.util.List;

import org.apache.ibatis.annotations.One;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;

import cn.bjsxt.pojo.Student;
/**
 * 通过注解,直接省略配置文件的书写
 * results=>resultMap
 * result=>result
 * @One=>association
 * @author chy
 *
 */
public interface StudentMapper {
    
    @Select("select * from t_student")
    @Results(value= {
            @Result(column="id",property="id",id=true),
            @Result(property="name",column="name"),
            @Result(column="age",property="age"),
            @Result(column="gender",property="gender"),
            @Result(column="cid",property="cid"),
            @Result(property="clazz",one=@One(select="cn.bjsxt.mapper.ClazzMapper.selById"),column="cid")
            
    })
    List<Student> sel();
    
    
    
}
相关文章
|
6月前
|
SQL XML Java
【mybatis】第二篇:@Select注解中加入字段判断
【mybatis】第二篇:@Select注解中加入字段判断
|
4天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
14天前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
43 5
|
14天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
35 3
|
20天前
|
SQL 存储 数据库
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
94 3
|
19天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
39 1
|
2月前
|
SQL XML Java
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
文章介绍了MyBatis的简单增删改查操作,包括创建数据表、实体类、配置文件、Mapper接口及其XML文件,并解释了`#{}`预编译参数和`@Param`注解的使用。同时,还涵盖了resultType与resultMap的区别,并提供了完整的代码实例和测试用例。
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
|
2月前
|
Java 数据库连接 数据格式
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
IOC/DI配置管理DruidDataSource和properties、核心容器的创建、获取bean的方式、spring注解开发、注解开发管理第三方bean、Spring整合Mybatis和Junit
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
|
3月前
|
SQL Java 数据库
5、Mybatis-Plus 常用注解
这篇文章详细介绍了Mybatis-Plus中常用的注解,包括解决实体类与数据库表名不一致、字段不匹配的问题,主键生成策略的配置,以及逻辑删除的实现方法。
5、Mybatis-Plus 常用注解
|
3月前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(7、使用注解开发)
这篇文章讲述了如何使用MyBatis框架的注解方式进行开发,包括在接口上使用注解定义SQL语句,并通过动态代理实现对数据库的增删改查操作,同时强调了接口需要在核心配置文件中注册绑定。