MyBatis注解详解
时间:2022-07-22
本文章向大家介绍MyBatis注解详解,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
- 注解开发
a) 注解是用于描述代码的代码. 例如: @Test(用于描述方法 进行 junit 测试), @Override(用于描述方法的重写), @Param(用于描述属性的名称) b) 注解的使用风格: @xxx(属性), 使用前必须先导包 c) 使用注解一般用于简化配置文件. 但是, 注解有时候也不 是很友好(有时候反而更麻烦), 例如动态 SQL. d) 关于注解的属性 属性的设定方式是: 属性名=属性值 e) 关于属性值的类型 基本类型和 String, 可以直接使用双引号的形式 数组类型, name={值 1, 值 2, …}; 如果数组元素只有 一个, 可以省略大括号 对象类型, name=@对象名(属性) 如果属性是该注解的默认属性, 而且该注解只配置这 一个属性, 可以将属性名省略 f) 注解和配置文件可以配合使用
2 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);
}
3 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();
}
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- Android开发之如何自定义数字键盘详解
- 在Android上实现HttpServer的示例代码
- Linux /etc/network/interfaces配置接口方法
- Android中Service和Activity相互通信示例代码
- Android编程实现定时发短信功能示例
- Android实现新浪微博一键分享的实例代码
- Android实现常见的验证码输入框实例代码
- Android实现加载状态视图切换效果
- Retrofit + OkHttp缓存处理的示例代码
- Android图片实现压缩处理的实例代码
- Windows10安装linux子系统的两种方式(图文详解)
- Android 图片处理避免出现oom的方法详解
- session登陆成功第四篇4
- Android编程使用pull方式解析xml格式文件的方法详解
- Android中ActionBar和ToolBar添加返回箭头的实例代码