04-插入操作更新操作删除操作

保存更新删除

目录

  • 插入操作
  • 获取插入的最后一个id
  • 更新操作
  • 删除操作

插入操作

映射文件 Customer.xml :
插入数据的标签为 insert,与查询 select 区分开来。
parameterType 是输入参数类型,这里指定为 Customer 对象,即需要传入一个 Customer 类型的参数。
由于传入参数不是单个简单类型值,#{} 中的名字必须与类的属性对应。

映射文件中的代码如下:

<?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="myTest"><!--添加客户--><insert id="insertCustom" parameterType="com.itlike.domain.Customer">INSERT INTO `customer` (cust_id, cust_name, cust_profession, cust_phone, email)VALUES (#{cust_id}, #{cust_name}, #{cust_profession}, #{cust_phone}, #{email});</insert></mapper>

测试类 MyTest.java :
查询的时候不需要提交事务,但是当要更改数据库当中的记录时,执行 sql 时需要手动提交事务:sqlSession.commit();

测试类中的代码如下:

public class MyTest {/*添加客户*/@Testpublic void test4(){SqlSession sqlSession = MybatisUtils.openSession();Customer customer = new Customer();customer.setCust_name("后裔");customer.setCust_phone("18937485936");sqlSession.insert("insertCustom", customer);// 当要更改数据库当中的记录时,执行 sql 时要自己提交事务// 手动提交事务sqlSession.commit();sqlSession.close();}}

运行效果:数据库中成功插入数据。

Opening JDBC Connection
Created connection 1615056168.
Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection@6043cd28]
==>  Preparing: INSERT INTO `customer` (cust_id, cust_name, cust_profession, cust_phone, email) VALUES (?, ?, ?, ?, ?); 
==> Parameters: null, 后裔(String), null, 18937485936(String), null
<==    Updates: 1

在这里插入图片描述

获取插入的最后一个id

<!--添加客户-->
<insert id="insertCustom" parameterType="com.itlike.domain.Customer">/*获取插入的最后一个id*/<selectKey keyColumn="cust_id" keyProperty="cust_id" resultType="Integer" order="AFTER">SELECT last_insert_id()</selectKey>INSERT INTO `customer` (cust_id, cust_name, cust_profession, cust_phone, email)VALUES (#{cust_id}, #{cust_name}, #{cust_profession}, #{cust_phone}, #{email});
</insert>

参数说明:

  • keyColunm:指定要获取的最后一个属性。
  • keyProperty:将获取的属性赋给插入对象的哪个属性。
  • resultType:获取的属性的类型。
  • order:BEFORE为在sql执行之前获取属性;AFTER 为在sql执行之后获取属性。
public void test4(){SqlSession sqlSession = MybatisUtils.openSession();Customer customer = new Customer();customer.setCust_name("后裔6");customer.setCust_phone("18937485936");sqlSession.insert("insertCustom", customer);// 当要更改数据库当中的记录时,执行 sql 时要自己提交事务// 手动提交事务sqlSession.commit();System.out.println(customer);sqlSession.close();
}

运行结果:(省略大部分日志,留下打印结果),插入后可以获取插入的最后一个ID。

Customer{cust_id=20, cust_name='后裔6', cust_profession='null', cust_phone='18937485936', email='null'}

注:为什么需要 keyProperty,为什么获取了ID后还要将它赋给插入对象?
因为如果不设定ID插入对象的话,实际上插入对象的ID一般是靠自动生成的,在插入完后获取时,获取的为 null,如下是不写 keyProperty 的后果:
在这里插入图片描述

更新操作

映射文件 Customer.xml :
更新数据的标签为 update;
代码如下:

<!--更新-->
<update id="updateCustomer" parameterType="com.itlike.domain.Customer">UPDATE `customer` SET cust_name = #{cust_name} WHERE cust_id = #{cust_id}
</update>

测试类 MyTest.java:更新操作需要传入一个对象,这个对象可以根据 id 查出来;也可以自己创建。如果是自己创建的对象,必须要有 id 属性。

/*更新操作*/
@Test
public void update(){SqlSession sqlSession = MybatisUtils.openSession();Customer customer = sqlSession.selectOne("queryCustomerById",11); // 根据id查出来一个对象customer.setCust_name("孙悟空"); // 修改名字sqlSession.update("updateCustomer", customer);sqlSession.commit();sqlSession.close();
}

运行效果:成功更新id为11的客户。

==>  Preparing: SELECT * FROM `customer` WHERE cust_id = ? 
==> Parameters: 11(Integer)
<==    Columns: cust_id, cust_name, cust_profession, cust_phone, email
<==        Row: 11, 李信, 战士, 13728964922, lixin@qq.com
<==      Total: 1
==>  Preparing: UPDATE `customer` SET cust_name = ? WHERE cust_id = ? 
==> Parameters: 孙悟空(String), 11(Integer)
<==    Updates: 1

删除操作

映射文件 Customer.xml :
删除数据的标签为 delete;
代码如下:

<!--删除-->
<delete id="deleteCustomer" parameterType="com.itlike.domain.Customer">DELETE FROM `customer` WHERE cust_id = #{cust_id}
</delete>

测试类 MyTest.java:删除操作需要传入一个对象。

/*删除操作*/
@Test
public void delete(){SqlSession sqlSession = MybatisUtils.openSession();Customer customer = sqlSession.selectOne("queryCustomerById", 10);sqlSession.delete("deleteCustomer", customer);sqlSession.commit();sqlSession.close();
}

运行效果:成功删除id为10的客户。

==>  Preparing: SELECT * FROM `customer` WHERE cust_id = ? 
==> Parameters: 10(Integer)
<==    Columns: cust_id, cust_name, cust_profession, cust_phone, email
<==        Row: 10, 阿木木, 辅助, 13398908928, 13398908928@qq.com
<==      Total: 1
==>  Preparing: DELETE FROM `customer` WHERE cust_id = ? 
==> Parameters: 10(Integer)
<==    Updates: 1

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

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

相关文章

微软跨平台移动开发工具套件HockeyApp宣布免费

HockeyApp 是一款领先的移动崩溃分析和应用发布服务&#xff0c;可为开发者提供实时崩溃分析报告、用户反馈、测试版分发平台以及测试分析等功能&#xff0c;于 2016 年被微软收购&#xff0c;随后集成在了 Visual Studio 应用中心中&#xff0c;与 Xamarin Insights 一起提供移…

P3914-染色计数【树形dp】

正题 题目链接:https://www.luogu.org/problemnew/show/P3914 题目大意 nnn个点每个点有些可以染的颜色&#xff0c;要求相邻颜色不相同&#xff0c;方案总数。 解题思路 树形dpdpdp&#xff0c;定义fx,if_{x,i}fx,i​表示点xxx的染颜色iii的方案数。然后定义zx∑i1mfxiz_x\s…

ASP.NET Core使用静态文件、目录游览与MIME类型管理

前言今天我们来了解了解ASP.NET Core中的静态文件的处理方式.以前我们寄宿在IIS中的时候,很多静态文件的过滤 和相关的安全措施 都已经帮我们处理好了.ASP.NET Core则不同,因为是跨平台的,解耦了IIS,所以这些工作 我们可以在管道代码中处理.正文在我们的Web程序开发中,肯定要提…

P5283-[十二省联考2019]异或粽子【可持久化Trie,堆】

正题 题目链接:https://www.luogu.org/problemnew/show/P5283 题目大意 给定一个序列&#xff0c;求kkk个不同的的[l..r][l..r][l..r]的区间异或值的和最大。 解题思路 先让aiaixorai−1a_ia_i\ xor\ a_{i-1}ai​ai​ xor ai−1​(异或前缀和)。 然后现在问题变成了求kkk对最…

ES快速入门

转载自 ES快速入门 3 ES快速入门 ES作为一个索引及搜索服务&#xff0c;对外提供丰富的REST接口&#xff0c;快速入门部分的实例使用head插件来测试&#xff0c;目的是对ES的使用方法及流程有个初步的认识。 3.1 创建索引库 ES的索引库是一个逻辑概念&#xff0c;它包括了分…

05-传统开发模式DAO

传统开发模式DAO 目录 定义接口 CustomerDao.java实现接口 CustomerDaoImpl.java测试类在传统开发模式DAO下&#xff0c;我们自己先定义好接口&#xff0c;然后再去定义实现类&#xff0c;在实现类中实现接口的操作。到时候只需要创建一个 dao 对象&#xff0c;即可调用其中的…

AspnetCore 2.0 自动API文档生成组件,支持protobuffer

关于API文档自动生成&#xff0c;用于对APP端的开发帮助文档生成&#xff0c;默认ProtoBuffer传输格式。本项目并不是RESTful风格&#xff0c;是面向功能的API类型。ApiDoc的作用是根据定义好的API接口和注释来自动生成给内部开发者提供的API对接文档。欢迎Star一下&#xff0c…

P5127-子异和【线段树,树链剖分,位运算】

正题 题目链接:https://www.luogu.org/problemnew/show/P5127 题目大意 定义一个序列的子异和为所有自己的异或和的和。 然后有点权的树&#xff0c;要求支持路径异或和路径求子异和。 解题思路 首先树链剖分是肯定的&#xff0c;然后我们考虑用哪个数据结构。 从每个位单独…

06-Mapper动态代理

Mppaer 动态代理 目录 创建 Mapper 工程定义接口的要求测试类Mapper 中参数传递单个参数多个参数param命名参数多个参数封装成 Map多个参数之 POJO参数处理源码分析之前我们一直都使用传统开发模式DAO&#xff0c;即定义接口&#xff0c;然后定义实现类。这个其实是较为繁琐的…

ASP.NET Core MVC中的 [Required]与[BindRequired]

在开发ASP.NET Core MVC应用程序时&#xff0c;需要对控制器中的模型校验数据有效性&#xff0c;元数据注释(Data Annotations)是一个完美的解决方案。元数据注释最典型例子是确保API的调用者提供了某个属性的值&#xff0c;在传统的ASP.NET MVC中使用的是RequiredAttribute特性…

ES集群管理

转载自 ES集群管理 8 集群管理 ES通常以集群方式工作&#xff0c;这样做不仅能够提高 ES的搜索能力还可以处理大数据搜索的能力&#xff0c;同时也增加了系统的容错能力及高可用&#xff0c;ES可以实现PB级数据的搜索。 下图是ES集群结构的示意图&#xff1a; 从上图总结以下…

【Java探索之旅】我与Java的初相识(完):注释,标识符,关键字

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Java入门到精通 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一. Java的注释方式二. 标识符三. 关键字四. 全篇总结 &#x1f4d1;前言 在Java编程…

P5290-[十二省联考2019]春节十二响【贪心,堆】

正题 题目链接:https://www.luogu.org/problemnew/show/P5290 题目大意 将一棵树的所有节点分城若干个组。每个组的价格是这个组中价格最大的点&#xff0c;要求这个组中没有任何祖孙关系。 求所有组的权值和最小。(1号为根节点) 解题思路 我们先想10,11,1210,11,1210,11,12…

07-MyBatis 核心配置文件

MyBatis 核心配置文件 目录 properties 定义属性及读取属性文件settings 设置运行时行为typeAliases 类型别名定义单个别名批量定义别名typeHandlers 类型处理器Plugins&#xff08;后续有文章专门介绍这个&#xff09;Environments 运行环境databaseIDProvider 定义数据库厂…

Office 365也是.NET Core应用开发新战场

最近有幸阅读了陈希章花了一年时间为国内开发者贡献的《Office 365 开发入门指南》。 虽然早期接触过SharePoint的开发&#xff0c;2007年之后就再也没有接触SharePoint的开发&#xff0c;这次阅读这本书让我重新认识了Office的系统开发技术&#xff0c;让我意识到现在的Office…

jzoj4802-[GDOI2017模拟9.24]探险计划【费用流,拆点】

正题 题目大意 一个nnn行的不完全矩阵第iii行有mi−1mi-1mi−1个格子&#xff0c;然后每个格子有危险度。 每次可以从(i,j)(i,j)(i,j)走到(i−1,j)(i-1,j)(i−1,j)或(i−1,j−1)(i-1,j-1)(i−1,j−1) 求 m次&#xff0c;每个格子和路不可以重复走的最小危险度。m次&#xff0…

Scala与Java差异(一)之基础语法

一、Scala解释器的使用 &#xff08;1&#xff09;REPL Read&#xff08;取值&#xff09;-> Evaluation&#xff08;求值&#xff09;-> Print&#xff08;打印&#xff09;-> Loop&#xff08;循环&#xff09;。 scala解释器也被称为REPL&#xff0c;会快速编译…

08-输出类型

输出类型 目录 输出简单类型输出 Map 类型key:列名 value:列名对应的值key:自己指定的列 value:自定义对象resultMap输出简单类型 CustomerMapper.java&#xff1a;返回值为简单类型。 public interface CustomerMapper {/*查询总数*/public Integer getAccountCustomer();…

在Ubuntu 16.04环境下安装Docker-CE(附视频教程)

“ 任何的课程都逃不开理论的支持”久等了各位&#xff0c;上一篇说Docker开始的消息已经过去了一周多的时间&#xff0c;今天推送的消息是告诉大家视频可以学习了&#xff01;52ABP .NET CORE QQ群 : 633751348大纲Docker的介绍Ubuntu下安装Docker快速体验Docker利用Docker搭…

jzoj4800-[GDOI2017模拟9.24]周末晚会【dp,循环重构】

正题 题目大意 nnn个人的圆桌&#xff0c;可以放男可以放女&#xff0c;然后要求不能有连续kkk个女生坐在一起。求方案总数。 解题思路 先不考虑圆桌&#xff0c;设fi,jf_{i,j}fi,j​表示放了i个人&#xff0c;最前面有连续jjj个女生&#xff0c;动态转移方程显然 fi,jfi−1,j…