【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法


增删改查操作


接下来,我们来实现一下用户的增加、删除和修改的操作。


**( Insert )**


UserInfoMapper接口:

我们写好UserInfoMapper接口后,自动生成 XML 代码;


UserInfoMapper.xml实现:


增删改查方法命名规范


如果我们在 mapper 接口的方法名没有 insert,select,update,delete 这四个单词,自动生成 XML 代码时,会出现下列提示,来确认我们的方法属于增删改查中的哪一个类型:


上图遇到的问题其实涉及到了 Mybatis 各层方法的命名规范问题:


接下来,我们回到正题,在 XML 文件对应 insertUser() 接口的位置写出如下 SQL:

sql 复制代码
insert into user_info(username, `password`, age) 
values(#{username}, #{password}, #{age})

此时,这条 insert 的 SQL 也涉及到一个传参的问题;

根据上面的 SQL ,我们是把参数 username,password,age 放到对象 userInfo 中了,在 XML 中就要从这个传过去的对象中,获取需要的属性;

  • MyBatis 是先有 XML 开发方式,才有注解开发方式,注解的设计也参考了 XML;
  • 如果我们的参数使用对象,那么 Mybatis 会自动生成按对象属性 username , age , password 这样的参数,而不需要我们通过 userInfo.age 这样的方法来获取属性参数;
  • 我们只需要区分数据库字段,和被 #{}包含着的 java 属性即可

接下来,我们生成测试类方法,并且写出对应逻辑,执行程序,观察日志结果:


刷新数据库的 user_info 表,可以发现,我们已经成功插入数据:


@Param****设置参数名称


如果使用@Param设置参数名称的话,使用方法和注解类似,但是 java 在#{} 属性需要通过从命名对象调用获得:


  • UserInfoMapper接口:

  • UserInfoMapper.xml实现:

生成并执行测试类方法:


观察错误日志,发现程序成功运行:


返回自增****id


接口定义不变,Mapper.xml实现设置useGeneratedKeyskeyProperty属性。


观察打印日志:


我们再来查看表:

通过上述的方法,我们可以拿到数字最大的自增主键;


我们可以顺便回忆以下,使用 @Option 注解是怎么拿到自增 id 的:


**( Update )**


写出 UserInfoMapper接口,并且自动生成 UserInfoMapper.xml 文件,写出对应的 SQL


生成测试类方法并执行:


查看表:


**( Delete )**


UserInfoMapper接口 和 UserInfoMapper.xml实现:



我们再查看表,发现 Id= 15 的记录已经被删除了:


**( Select )**


【MyBatis】深入解析 MyBatis:关于注解和 XML 的 MyBatis 开发方案下字段名不一致的的查询映射解决方案-CSDN博客


开发中使用注解还是 XML 的方式?


关于开发中使用哪种模式这个问题,没有明确答案。仁者见仁智者见智,并没有统一的标准,更多是取决于你的团队或者项目经理、项目负责人。


相关推荐
quikai19811 小时前
python练习第六组
java·前端·python
222you1 小时前
线程的常用方法
java·开发语言
他是龙5511 小时前
43:SQL注入进阶(请求类型、方法与格式实战)
数据库·sql
是梦终空1 小时前
JAVA毕业设计259—基于Java+Springboot+vue3工单管理系统的设计与实现(源代码+数据库+开题报告)
java·spring boot·vue·毕业设计·课程设计·工单管理系统·源代码
用户2190326527351 小时前
Spring Boot 集成 Redis 实现看门狗 Lua 脚本分布式锁
java·后端
zybsjn1 小时前
ShardingSphere 启动报错 “Unknown table ‘keywords‘ in information_schema“ 完整解决方案
java
木卫二号Coding1 小时前
affine+docker+postgresql+备份数据库
数据库·docker·容器
月明长歌1 小时前
【码道初阶】【LeetCode 102】二叉树层序遍历:如何利用队列实现“一层一层切蛋糕”?
java·数据结构·算法·leetcode·职场和发展·队列
codingPower1 小时前
制作ftl文件通过FreeMarke生成PDF文件(含图片处理)
java·开发语言·pdf
R.lin1 小时前
Spring AI Alibaba 1.1 正式发布!
java·后端·spring