MyBatis:注解开发

在 MyBatis 的开发体系中,注解开发作为 XML 配置的补充方案,以其简洁直观的语法大幅简化了基础 CRUD 操作的代码编写。然而需要明确的是,该方式更适用于简单业务场景,不推荐在生产环境中大规模使用—— 复杂 SQL 的维护性、动态 SQL 的灵活性等方面仍不及 XML 配置。本文将从核心注解、配置方式、关联查询实现到测试流程,全面拆解 MyBatis 注解开发的关键知识点。

MyBatis 提供了一套原生注解对应 SQL 的增删改查操作,无需编写 XML 映射文件,直接在 Mapper 接口方法上添加注解即可完成 SQL 绑定,核心注解如下:

@Insert:添加 @Update:修改 @Delete:删除 @Select:查询 @Result:实现结果集封装 @Results:可以和@Result一起使用,封装多个结果集 @One:实现一对一和多对一的结果集封装 @Many:实现一对多结果级封装

一、使用注解完成CURD

1.SqlMapConfig,xml配置文件

使用注解开发时,需在 MyBatis 核心配置文件SqlMapConfig.xml中声明 Mapper 接口的扫描路径,让 MyBatis 能够识别注解对应的映射关系,主要有两种配置方式:

<mappers> <!--第一种方式:class引入接口,只能引入一个接口--> <mapper class="com.qcby.dao.UserAnnoDao"/> <!--第二种方式:针对com.qcby.dao包下的所有的接口--> <package name="com.qcby.dao"/> </mappers>

注意:包扫描方式要求 Mapper 接口名与 XML 映射文件名(若存在)一致,且放置在同一包下,否则会导致映射失效。

2.UserDao接口方法和注释的编写

import com.qcby.entity.User; import org.apache.ibatis.annotations.*; import javax.jws.soap.SOAPBinding; import java.util.List; public interface UserDao { //查询所有 @Select("select * from user") @Results(id="userMap",value = { @Result(property = "id",column = "id"), @Result(property = "username",column = "username"), @Result(property = "birthday",column = "birthday"), @Result(property = "sex",column = "sex"), @Result(property = "address",column = "address") }) public List<User> findAll(); //通过ID查询 @Select("select * from user where id = #{id}") @ResultMap(value = "userMap") public User findById(int id); //增加 @Insert("insert into user(username,birthday,sex,address) values(#{username},#{birthday},#{sex},#{address})") @SelectKey(statement="select last_insert_id()",keyColumn = "id",keyProperty = "id",before =false,resultType =Integer.class) public int insert(User user); //更新 @Update("update user set username = #{username},birthday = #{birthday},sex = #{sex},address = #{address} where id = #{id}") public int update(User user); //删除 @Delete("delete from user where id = #{id}") public int delete(int id); //查询数量 @Select("select count(*) from user") public int findCount(); //模糊查询 @Select("select * from user where username like concat('%',#{username},'%')") public List<User> findByName(String username); }

3.UserTest测试方法的编写

public class UserTest { private InputStream in = null; private SqlSession session = null; private UserDao mapper = null; @Before //前置通知, 在方法执行之前执行 public void init() throws IOException { //加载主配置文件,目的是为了构建SqlSessionFactory对象 in = Resources.getResourceAsStream("SqlMapConfig.xml"); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory工厂对象创建SqlSesssion对象 session = factory.openSession(); //通过Session创建UserDao接口代理对象 mapper = session.getMapper(UserDao.class); } @After //@After: 后置通知, 在方法执行之后执行 。 public void destory() throws IOException { //释放资源 session.close(); in.close(); } /** * 测试查询所有的方法 */ @Test public void findAll() throws IOException { List<User> users = mapper.findAll(); for (User user:users) { System.out.println(user.toString()); } } @Test public void findById(){ User user = mapper.findById(4); System.out.println(user.toString()); } @Test public void insert(){ User user = new User(); user.setSex("女"); user.setUsername("小美"); user.setBirthday(new Date()); user.setAddress("保定"); int insert = mapper.insert(user); session.commit(); System.out.println(insert); } @Test public void update(){ User user = new User(); user.setId(22); user.setSex("女"); user.setUsername("小美"); user.setBirthday(new Date()); user.setAddress("上海"); int insert = mapper.update(user); session.commit(); System.out.println(insert); } @Test public void delete(){ int delete = mapper.delete(22); session.commit(); System.out.println(delete); } @Test public void findCount(){ int count = mapper.findCount(); session.commit(); System.out.println(count); } @Test public void findByName(){ List<User> list = mapper.findByName("%a%"); for (User user : list) { System.out.println(user); } session.close(); } }

二、多对一的注解查询

1.多对一立即加载查询

①.StudentDao接口的方法编写

@Select(" SELECT student.*,teacher.Tname FROM student LEFT JOIN teacher on student.t_id = teacher.id") @Results(value = { @Result(property = "id",column = "id"), @Result(property = "Sname",column = "Sname"), @Result(property = "sex",column = "sex"), @Result(property = "age",column = "age"), @Result(property = "t_id",column = "t_id"), @Result(property = "teacher.Tname",column = "Tname") }) public List<Student> getStudent();

②.进行测试

@Test public void getStudent(){ List<Student> student = mapper.getStudent(); for (Student student1:student) { System.out.println(student1.toString()); } }

2.多对一延迟加载查询

①.StudentDao接口的方法编写

@Select("select * from student") @Results(value = { @Result(property = "id",column = "id"), @Result(property = "Sname",column = "Sname"), @Result(property = "sex",column = "sex"), @Result(property = "age",column = "age"), @Result(property = "teacher",column = "t_id",one=@One(select = "com.qcby.dao.TeacherDao.getTeacher",fetchType = FetchType.LAZY)) }) public List<Student> getStudent();

②.TeacherDao接口的方法编写

@Select("select * from teacher where id = #{t_id}") Teacher getTeacher(Integer id);

③.进行测试

@Test public void getStudent(){ List<Student> student = mapper.getStudent(); for (Student student1:student) { System.out.println(student1.toString()); } }

三、一对多的注解查询

1.一对多延迟加载查询

①.TeacherDao接口的方法编写

//查询所有延迟加载 @Select("select * from Teacher") @Results(value = { @Result(property = "id",column = "id"), @Result(property = "Tname",column = "Tname"), @Result(property = "students",column = "id",many =@Many(select = "com.qcby.dao.StudentDao.findByUid",fetchType = FetchType.LAZY)) }) public List<Teacher> findAllLazy();

②.StudentDao接口的方法编写

@Select("select * from student where t_id = #{t_id}") public Student findByUid(int uid);

③.进行测试

@Test public void findAllLazy(){ List<Teacher> list = mapper.findAllLazy(); for (Teacher teacher: list) { System.out.println(teacher.toString()); } }

四、使用建议:注解开发 vs XML 配置

很多开发者纠结 “注解还是 XML”,核心是未明确二者的适用边界。以下从多个维度对比,给出场景化选择建议::

对比维度注解开发XML 配置
适用场景简单 CRUD、少量参数、无复杂逻辑的业务复杂 SQL、动态条件(if/foreach)、多表关联复杂场景
代码可读性简单 SQL 直观,复杂 SQL 混乱(注解内嵌套脚本)结构化清晰,SQL 与 Java 代码分离,易维护
动态 SQL 支持有限(需嵌入<script>标签,语法繁琐)原生支持,标签丰富(if/choose/foreach 等)
SQL 复用需通过 Java 方法复用,灵活性差支持<sql>标签抽取公共 SQL,复用性强
生产环境推荐度★★☆(仅适用于简单模块)★★★★★(通用首选)

总结建议

  1. 简单 CRUD 场景(如管理后台基础数据操作):可使用注解开发,提升开发效率。
  2. 复杂业务场景(如多表关联、动态条件查询、SQL 优化需求高):优先使用 XML 配置,保证代码可维护性和灵活性。
  3. 混合使用:核心复杂 SQL 用 XML 配置,简单辅助操作用注解,兼顾效率与维护性。

五、总结

MyBatis 注解开发的核心价值是 “简化简单场景的编码成本”,但切勿盲目追求 “无 XML” 而忽视其局限性。掌握核心注解的进阶用法、关联查询的优化技巧、配置规范与问题排查方法,才能在实际开发中灵活运用 —— 简单场景用注解提升效率,复杂场景用 XML 保证可维护性,二者结合方能最大化 MyBatis 的开发价值。

若你在使用过程中遇到具体问题(如动态 SQL 注解实现、多数据源适配),欢迎在评论区交流,后续将针对性输出进阶教程!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1160199.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大模型智能体工程实践:Rock Roll训练系统的构建与优化【收藏学习】

该研究提出智能体学习生态系统(ALE)&#xff0c;包含ROLL训练框架、ROCK环境和iFlow CLI工具三层架构。创新性IPA算法基于语义交互块进行信用分配&#xff0c;提升长程训练稳定性。基于百万轨迹数据训练的ROME模型在SWE-bench等基准上表现优异&#xff0c;仅用30B参数就接近GPT…

2026年AI产品市场格局:多模态崛起,音乐生成爆发,程序员必看

SimilarWeb的2026年全球AI报告显示&#xff1a;通用AI流量滞涨&#xff0c;OpenAI市占率降至65%以下&#xff0c;Gemini上升至20%&#xff1b;音乐和音频生成增速最高&#xff1b;多模态产品访问量上涨&#xff1b;图像、写作和自动化工具流量下滑。AI原生应用冲击传统互联网平…

大模型工程师转型攻略:无需985学历,四大核心能力助你轻松入行

本文破除了大模型工程师高门槛的迷思&#xff0c;指出大多数企业需要的是应用工程师而非算法研究员。通过分析真实转型案例&#xff0c;文章总结出四大核心能力&#xff1a;提示工程、RAG检索增强生成、模型微调和工程部署能力。零基础程序员可通过系统学习一个月内产出可演示项…

【PaperXie毕业论文】从零到一的智能写作革命:AI如何重塑你的学术创作全流程

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/dissertationhttps://www.paperxie.cn/ai/dissertation ——告别熬夜改稿&#xff0c;开启“输入即输出”的高效学术时代 在2026年的今天&#xff0c;当人工智能已深度…

短剧广告联盟APP开发:数据对接与播放量、广告曝光量、收益联动统计方案

在短剧广告联盟APP的商业化体系中&#xff0c;播放量、广告曝光量与收益数据是衡量运营效果的核心指标&#xff0c;而三者的联动统计与精准对接&#xff0c;更是实现 “内容优化 - 广告策略调整 - 收益提升” 的关键前提。多数短剧APP 在开发阶段易陷入 “数据割裂、统计延迟、…

GEO营销全链路方案:附近搜索引流 + 到店优惠 + 会员裂变

一、方案概述本方案为实体门店打造基于地理位置&#xff08;GEO&#xff09;的数字化营销闭环&#xff0c;通过“线上精准引流-到店转化锁客-会员裂变增长”全链路设计&#xff0c;实现低成本、高效率的客源增长。二、核心玩法架构text附近搜索引流 → 到店专享优惠 → 会员体系…

羟基聚乙二醇多巴胺,HO-PEG-Do试剂的全能应用图解

试剂基本信息中文名&#xff1a;羟基聚乙二醇多巴胺&#xff0c;HO-PEG-醇多巴胺英文名&#xff1a;HO-PEG-Do&#xff0c;HO-PEG-dopamine分子量PEG&#xff1a;1k&#xff0c;2k&#xff0c;3.4k&#xff0c;5k&#xff0c;10k&#xff0c;20k&#xff08;其它分子量可按需定…

AI 赋能学术:paperxie 毕业论文功能,如何让硕士论文写作效率提升 80%?

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/dissertationhttps://www.paperxie.cn/ai/dissertation 在学术写作愈发依赖数字化工具的今天&#xff0c;“论文难写” 早已不是学生独有的焦虑 —— 从选题方向的模糊…

paperxie 科研绘图:从流程图到专业图表,一键搞定学术可视化的 “高效工具”

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/drawinghttps://www.paperxie.cn/drawing 学术写作中&#xff0c;“图表可视化” 是让研究成果更直观的关键 —— 但多数科研人员常陷入 “不会用专业绘图软件”“图表不符…

Paperxie 毕业论文:从选题到定稿的一站式智能写作解决方案

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/dissertationhttps://www.paperxie.cn/ai/dissertation 对于每一位高校毕业生而言&#xff0c;毕业论文不仅是学业生涯的收官之作&#xff0c;更是学术能力的集中考验。…

通信原理篇---第一类部分响应的预编码和相关编码

我们用「事先打暗号的猜谜游戏」来彻底讲懂预编码和相关编码&#xff0c;你会惊叹于它们的巧妙。核心比喻&#xff1a;猜数字游戏假设我们要玩一个游戏&#xff1a;我快速报出一串数字给你听&#xff0c;你要猜出我心中原始的数字序列。但是有个讨厌的规则&#xff1a;我每次报…

大数据集成性能测试:JMeter压测ETL任务,找出性能瓶颈

大数据集成性能测试实战:用JMeter压测ETL任务,精准定位性能瓶颈 摘要/引言:你为什么需要系统的ETL性能测试? 凌晨3点,你揉着眼睛盯着监控大屏——昨天的用户订单ETL任务还没跑完。业务部门早早就催着要“季度复购率报表”,而你只能一遍遍地刷新Spark UI,看着“Stage 3…

通信原理篇---第二类部分响应的预编码和相关编码

我们用「带负号的声音接力」这个游戏来彻底搞懂第四类部分响应的预编码和相关编码。这个类比会让你发现它和第一类的精妙差异。核心比喻&#xff1a;带负号的猜数游戏这次的游戏规则变了&#xff0c;更奇特&#xff1a;新规则&#xff1a;我报出的数字 我当前的数字 - 你猜的上…

JSON文件中显示为 \uXXXX 字符 的解决办法

在JSON文件中&#xff0c;有些字段值是直接使用汉字&#xff0c;而有些字段值则是以 \u 开头的字符&#xff0c;这是因为&#xff1a;✅ 正确显示的汉字&#xff1a;这些是正常编码的中文字符&#xff0c;文件保存格式为 UTF-8&#xff0c;浏览器或编辑器能正确识别并显示为中文…

MyBatis处理模糊查询

根据用户名模糊查询用户信息 SQLMapper package com.baidu.mybatis.mapper;import com.baidu.mybatis.pojo.User; import org.apache.ibatis.annotations.Param;import java.util.List;public interface SQLMapper {// 根据用户名模糊查询用户信息List<User> getUserB…

如何用纯 HTML 文件实现 Vue.js 应用,并通过 CDN 引入 Element UI

相关名词解释Vue.jsVue.js&#xff1a;是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建&#xff0c;提供声明式的、组件化的编程模型&#xff0c;可高效开发用户界面。具有响应式数据绑定等特性&#xff0c;能自动跟踪数据变化并更新 DOM。…

MyBatis处理批量删除

SQLMapper测试SQLMapper.xml 使用#{}&#xff0c;由于#{}在解析时候会带有单引号&#xff0c;所以会出问题应该使用${}

【无人机追踪】基于资源福利任务分配算法的无人机集群任务分配算法,完成目标攻击任务的基础上,通过优化资源分配和能耗控制附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1f34…

私有化大模型部署:企业AI落地的关键技术方案

私有化大模型部署:企业AI落地的关键技术方案 引言:为什么企业需要私有化大模型? 1. 企业的「AI落地痛点」 当企业尝试用AI解决实际问题时,公有云大模型(如GPT-4、文心一言) 往往无法满足核心需求: 数据隐私风险:金融、医疗等行业的敏感数据(如客户交易记录、患者病…

ue websocket 插件学习笔记

这个没有给连接参数怎么设置&#xff1a;