【2023.11.26】Mybatis注解学习

注解执行SQL语句

Mybatis的映射接口需要写在映射器xml的命名空间内。为了省略这一步,可以使用注解开发。

java 复制代码
    @Select("select * from artist where aID = #{a}")
    artist getArtistById(int a);

在接口的方法上加上注解@,注解中写明SQL语句即可省略映射器的SQL语句书写,不用写分号。

(注:此处若无法识别数据库的表,需要右键选择架构)

同时修改配置xml文件中的mapper标签:

XML 复制代码
<mapper class = "com.test.mapper.TestMapperInterface"/>
<!--    也可以直接注册整个包下的 <package name="com.test.mapper"/>   -->

resource: 映射器直接改为class: 接口,若多个接口都在同一个包下,也可以使用**package:**包名


注解自定义映射规则

使用SqlSession中的方法或映射器中的SQL语句都只能完成简单的Sql操作。复杂的操作需要我们自定义映射规则**@Results**注解来解决。

java 复制代码
@Results({
        @Result(id = true, column = "sid", property = "sid"),
        @Result(column = "sex", property = "name"),
        @Result(column = "name", property = "sex")
})
@Select("select * from student")

@ConstructorArgs({
        @Arg(column = "sid", javaType = int.class),
        @Arg(column = "name", javaType = String.class)
})
@Select("select * from student where sid = #{sid} and sex = #{sex}")

相比于映射器里书写的自定义映射规则,不需要写resultMap的id与type

如果要使用映射器中定义的映射规则,可以使用**@ResultMap**(id)注解,填写映射规则id即可。

如果要用接口写多个构造方法,可以使用**@ConstructorArgs**注解。

若方法中含有多个形参,需要用**@Param**注解将参数名强调一遍,否则会报错。

java 复制代码
@Select("select * from artist where aID = #{a} and asex = #{b}")
artist getArtistById(@Param("a")int a, @Param("b")int b);
相关推荐
数新网络1 小时前
赋能某跨境智慧物流:基于 AWS Graviton 的全栈数据平台实现 25% 成本节省
java·云计算·aws
C雨后彩虹1 小时前
ThreadLocal全面总结,从理论到实践再到面试高频题
java·面试·多线程·同步·异步·threadlocal
至此流年莫相忘1 小时前
Kubernetes核心概念
java·容器·kubernetes
Quintus五等升1 小时前
深度学习自用笔记
人工智能·笔记·深度学习·学习·机器学习·bert·numpy
予枫的编程笔记1 小时前
【Docker进阶篇】从入门到精通:Java应用Docker打包,最佳实践与多阶段构建详解
java·docker·容器化·dockerfile·多阶段构建·docker最佳实践·java镜像优化
yuuki2332331 小时前
【C++】模拟实现 红黑树(RBTree)
java·开发语言·c++
玄〤1 小时前
RabbitMQ高级篇总结(黑马微服务课day11)(包含黑马商城业务改造)
java·分布式·spring cloud·微服务·架构·rabbitmq
人道领域1 小时前
SSM框架从入门到入土(SSM框架整合)
java·spring boot·spring
fouryears_234171 小时前
源码阅读:Spring AI 框架是如何进行工具调用以及循环调用的过程
java·人工智能·spring·spring ai
acanab1 小时前
ros2 URDF学习
学习