[mybatis]Mapper XML Files_CUD

The true power of MyBatis is in the Mapped Statements. This is where the magic happens.

CUD

  • mybatis运行CUD直接定义以下类型返回值
    • Integer,Long,Boolean
  • 我们需要手动提交数据
    • sqlSessionFactory.openSession();—>手动提交
    • sqlSessionFactory.openSession(true);—>自动提交

接口:

package com.atguigu.mybatis.dao;import com.atguigu.mybatis.bean.Employee;public interface EmployeeMapper {public Employee getEmpById(Integer id);public Long addEmp(Employee employee);public boolean updateEmp(Employee employee);public void deleteEmpById(Integer id);}

映射文件:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.mybatis.dao.EmployeeMapper"><select id="getEmpById" resultType="employee">select id,last_name,email,gender from tb1_employee where id = #{id}</select><!--parameterType:可以省略--><insert id="addEmp" parameterType="com.atguigu.mybatis.bean.Employee" useGeneratedKeys="true" keyProperty="id" >insert into tb1_employee(last_name,email,gender)values(#{lastName},#{email},#{gender})</insert><!--public void updateEmp(Employee employee)--><update id="updateEmp">update tb1_employeeset last_name = #{lastName},email = #{gender}where id = #{id}</update><!--public void deleteEmpById(Integer id);--><delete id = "deleteEmpById">delete from tb1_employee where id = #{id}
</delete></mapper>

在这里就测试一个addEmp函数:

  @Testpublic void test02() throws IOException {SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();SqlSession sqlSession = sqlSessionFactory.openSession();try{EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);Employee employee = new Employee(null, "jack", "jack@qq.com", "1");mapper.addEmp(employee);//手动提交数据sqlSession.commit();}finally {sqlSession.close();}}

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

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

相关文章

Strategy(策略)--对象行为型模式

Strategy&#xff08;策略&#xff09;–对象行为型模式 一、意图 定义一系列的算法&#xff0c;把它们一个个封装起来&#xff0c;并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。 二、动机 1.在软件构建过程中&#xff0c;某些对象使用的算法可能多种多…

12个Visual Studio调试效率技巧

在这篇文章中&#xff0c;我们假定读者了解VS基本的调试知识&#xff0c;如&#xff1a;F5 开始使用调试器运行程序F9 在当前行设置断点F10 运行到下一个断点处F5 从被调试的已停止程序恢复执行F11 步进到函数内&#xff08;如果当前程序指针指向一个函数&#xff09;F10 步过函…

Template Method(模板方法)--类行为型模式

Template Method&#xff08;模板方法&#xff09;–类行为型模式 一、意图 定义一个操作中的算法的骨架&#xff0c;而将一些步骤延迟到子类中。TemplateMethod使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。 二、动机 1.在软件构建过程中&#xff0c;对…

[mybatis]Mapper XML Files_获取自增主键的值

useGeneratedKeys “true”&#xff1b;使用自增主键获取主键值策略keyProperty&#xff1b;指定对应的主键属性&#xff0c;也就是mybatis获取主键值后&#xff0c;将这个值封装给javaBean的对应属性 <insert id"addEmp" useGeneratedKeys"true" keyP…

骚年快答 | 微服务架构中的BFF到底是啥?

【答疑解惑】| 作者 / Edison Zhou这是恰童鞋骚年的第263篇原创内容昨天的骚年快答《技术中台与业务中台都是啥玩意》一文中留下一个问题&#xff1a;BFF是啥&#xff1f;为啥在API网关和业务中台之间加入了一层BFF&#xff1f;考虑到在实际工作中&#xff0c;我的大部分同事都…

Visitor(访问者)--对象行为型模式

Visitor&#xff08;访问者&#xff09;–对象行为型模式 一、意图 表示一个作用于某个对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。 二、动机 1.在软件构建过程中&#xff0c;由于需求的改变&#xff0c;某些类层次结构中常…

[mybatis]映射文件_参数处理

参数处理 单个参数&#xff1a;mybatis不会做特殊处理 #{参数名}&#xff1a;取出参数值 多个参数&#xff1a;mybatis会做特殊处理 多个参数会被封装成一个map key&#xff1a;param1…paramN&#xff0c;或者参数的索引value&#xff1a;传入的参数值 #{}就是从map中获取指定…

骚年快答 | 技术中台与业务中台都是啥?

【答疑解惑】| 作者 / Edison Zhou这是恰童鞋骚年的第262篇原创内容最近有童鞋在我之前发布的《聊聊中台》一文中提问&#xff1a;技术中台是什么&#xff1f;和业务中台又有什么区别&#xff1f;考虑到在工作中&#xff0c;也有部分同事问过这个问题&#xff0c;我这里总结一下…

[mybatis]映射文件_参数处理_#和$取值区别

#{}&#xff1a;可以获取map中的值或者pojo对象属性的值${}&#xff1a;可以获取map中的值或者pojo对象属性的值 区别&#xff1a; #{}&#xff1a;是以预编译的形式&#xff0c;将参数设置到sql语句中&#xff0c;相当于原生jdbc的PreparedStatement&#xff1b;防止sql注入${…

平台or职位,你怎么选?

这里是Z哥的个人公众号每周五11&#xff1a;45 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「150」篇原创敬上大家好&#xff0c;我是Z哥。这周有位小伙伴和我聊到一个问题&#xff0c;选择工作的时候是平台重要还是职位重要&#xff1f;我想&#xff0c;很…

闲谈设计模式

闲谈设计模式Intro设计模式&#xff08;Design Pattern&#xff09;是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。了解这些前辈们总结出来的经验有助于帮助你写出来更优秀的代码&#xff0c;帮助你写出可扩展、可读、可维护的高质量代码。在极客时间里推出…

[mybatis]log4j

引入依赖&#xff1a; <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>在资源文件下写一个log4j配置文件: <?xml version"1.0" encoding"UT…

eShopOnContainers 知多少[11]:服务间通信之gRPC

1. 引言最近翻看最新3.0 eShopOncontainers源码&#xff0c;发现其在架构选型中补充了 gRPC 进行服务间通信。那就索性也写一篇&#xff0c;作为系列的补充。2. gRPC老规矩&#xff0c;先来理一下gRPC的基本概念。gRPC是Google开源的RPC框架&#xff0c;比肩dubbo、thrift、brp…

[mybatis]映射文件_参数处理_#取值时指定参数相关规则

jdbcType通常需要在某种特定的条件下被设置&#xff1a; 在我们数据为null的时候&#xff0c;有些数据库可能不能识别mybatis对null的默认处理。比如Oracle&#xff08;报错&#xff09;&#xff1b;jdbcType OTHER&#xff1a;无效的类型&#xff1b;因为mybatis对所有的null映…

龙芯开源社区上线.NET主页

龙芯团队从2019年7 月份开始着手.NET Core的MIPS64支持研发&#xff0c;经过将近一年的研发&#xff0c;在2020年6月18日完成了里程碑性的工作&#xff0c;在github CoreCLR 仓库&#xff1a;https://github.com/gsvm/coreclr&#xff0c; 随后受到.NET社区的很大参与热情鼓舞之…

[mybatis]映射文件_select_返回集合(List,Map)

select返回List public interface EmployeeMapper {public List<Employee> getEmpsByLastNameLike(String lastName);}<!-- public List<Employee> getEmpsByLastNameLike(String lastName);--><!--resultType;如果返回的是一个集合&#xff0c;要写集…

免费 | 数千个 Azure 官方高清矢量图标大放送!

点击上方关注“汪宇杰博客” ^_^导语我们平时绘制云应用架构图时&#xff0c;经常要用 Azure 各项服务的图标。不知各位会自己去截图&#xff0c;还是在浏览器 F12 里使劲抠图&#xff1f;是不是做PPT 5分钟&#xff0c;扣图2小时&#xff1f;现在用不着自己使劲啦&#xff0c;…

[mybatis]select_resultMap_自定义结果集映射规则

resultMap 自定义某个javaBean的封装规则 type&#xff1a;自定义规则的Java类型id&#xff1a;唯一id方便引用 指定主键列的封装规则 id&#xff1a;定义主键底层会有优化column&#xff1a;指定哪一列property&#xff1a;指定对应的javaBean属性 public interface Employ…

设计模式中的那些工厂

设计模式中的那些工厂Intro设计模式中有几个工厂模式&#xff0c;聊一聊这几个工厂模式的各自用法和使用示例&#xff0c;工厂模式包含简单工厂&#xff0c;抽象工厂&#xff0c;工厂方法&#xff0c;这些均属于创建型模式&#xff0c; 所谓创建型模式&#xff0c;就是说这几个…

[mybatis]映射文件_select_resultMap_关联查询

普通方式 public class Employee {private Integer id;private String lastName;private String email;private String gender;private Department dept;}public class Department {private Integer id;private String departmentName;}public interface EmployeeMapperPlus {…