品牌网站建设搭建/品牌定位

品牌网站建设搭建,品牌定位,网络公司经营范围怎么填写,山东建设银行社会招聘网站背景:通过Mybatis插入数据或更新数据,显示插入/更新成功,查询数据库,发现并未插入成功、数据也没更新成功。下面是Mapper文件 public interface TestOrmMapper {int insertByTest(Param("requestId") Integer requestI…

背景:通过Mybatis插入数据或更新数据,显示插入/更新成功,查询数据库,发现并未插入成功、数据也没更新成功。下面是Mapper文件

public interface TestOrmMapper {int insertByTest(@Param("requestId") Integer requestId, @Param("dataType") Integer dataType,@Param("roleKey") String roleKey, @Param("roleNameCn") String roleNameCn, @Param("roleNameEn") String roleNameEn);int updateById(@Param("id") Integer id, @Param("roleKey") String roleKey, @Param("roleNameCn") String roleNameCn, @Param("roleNameEn") String roleNameEn);
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ecology.mapper.TestOrmMapper"><insert id="insertByTest">insert into plm_role_project_bak(requestId, data_type, role_key, role_name_cn, role_name_en)values(#{requestId}, #{dataType}, #{roleKey}, #{roleNameCn}, #{roleNameEn})</insert><update id="updateById">update plm_role_project_bak set role_key = #{roleKey}, role_name_cn = #{roleNameCn}, role_name_en = #{roleNameEn} where id = #{id}</update>
</mapper>

调用代码块:

Integer requestId = 2938939;
TestOrmMapper testMapper = sqlSession.getMapper(TestOrmMapper.class);
int test = testMapper.insertByTest(requestId, 11, "role_01", "角色中文名", "role_name");
LOGGER.info("======>>>Insert请求结果test:{}", test);String roleKey = "role_02";
String roleName = "角色中文名";
String roleEnName = "role_code";
int id = testMapper.updateById(1, roleKey, roleEnName, roleName);
LOGGER.info("======>>>Update请求结果id:{}", id);

控制台执行的日志:

通过日志可看insert、update返回都是执行成功;但是数据库中的数据还是没有任何修改

本地调试一下,可以通过日志看到原因:插入的语句回滚连接数据库了,导致插入失败。

 这种情况下,我们可以使用 sqlSession.commit()手动执行提交事件,将数据提交到数据库中

//手动执行提交事件,将数据提交到数据库中,才真正成功插入到数据库中
sqlSession.commit();

或者我们在使用sqlSessionFactory.openSession()时候,将openSession( )的值设为 true 自动提交

 SqlSession sqlSession = sqlSessionFactory.openSession(true);

看DefaultSqlSessionFactory源码,可以看到提供了两个openSession方法

使用无参的方法时,需要配合commit使用,不然不会提交,导致数据操作回滚而失败

解决方式:

  • 将 openSession( )的值设为 true
SqlSession sqlSession = sqlSessionFactory.openSession(true);
  •  配合commit使用
SqlSession sqlSession = sqlSessionFactory.openSession();Integer requestId = 2938939;
TestOrmMapper testMapper = sqlSession.getMapper(TestOrmMapper.class);
int test = testMapper.insertByTest(requestId, 11, "role_01", "角色中文名", "role_name");
sqlSession.commit();//手动执行提交事件,将数据提交到数据库中,才真正成功插入到数据库中
LOGGER.info("======>>>Insert请求结果test:{}", test);String roleKey = "role_02";
String roleName = "角色中文名";
String roleEnName = "role_code";
int id = testMapper.updateById(1, roleKey, roleEnName, roleName);
sqlSession.commit();//手动执行提交事件,将数据提交到数据库中,才真正成功插入到数据库中
LOGGER.info("======>>>Update请求结果id:{}", id);

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

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

相关文章

【大模型系列篇】国产开源大模型DeepSeek-V3技术报告解析

DeepSeek-V3技术报告 目录 DeepSeek-V3技术报告 1. 摘要 2. 引言 3. DeepSeek V3 架构 3.1 基础架构 3.1.1. 多头潜在注意力 3.1.2. DeepSeekMoE和无辅助损失的负载均衡 3.2 多令牌预测 4. 基础设施 4.1 计算集群 4.2 训练框架 4.2.1. DualPipe算法与计算通信协同优…

负载均衡 - 一致性hash算法

构建场景 假如我们有三台缓存服务器编号node0、node1、node2&#xff0c;现在有3000万个key&#xff0c;希望可以将这些个key均匀的缓存到三台机器上&#xff0c;你会想到什么方案呢&#xff1f; 我们可能首先想到的方案&#xff0c;是取模算法hash&#xff08;key&#xff0…

洛谷P1334

题目如下 思路&#xff1a; 每次选择最短的两块木板进行合并&#xff0c;直到只剩下一块木板。使用最小堆&#xff08;优先队列&#xff09;来实现这一过程。使用最小堆&#xff1a; 将所有木板的长度放入最小堆&#xff08;优先队列&#xff09; 每次从堆中取出两块最短的木…

总结(尚硅谷Vue3入门到实战,最新版vue3+TypeScript前端开发教程)

1.Vue简介 2020年9月18日&#xff0c;Vue.js发布版3.0版本&#xff0c;代号&#xff1a;One Piece 1.1.性能的提升 打包大小减少41%。 初次渲染快55%, 更新渲染快133%。 内存减少54%。 1.2.源码的升级 使用Proxy代替defineProperty实现响应式。 重写虚拟DOM的实现和Tree-Shak…

【深度学习CV】【图像分类】从CNN(卷积神经网络)、ResNet迁移学习到GPU高效训练优化【案例代码】详解

摘要 本文分类使用的是resNet34,什么不用yolo v8&#xff0c;yolo v10系列,虽然他们也可以分类&#xff0c;因为yolo系列模型不纯粹&#xff0c;里面包含了目标检测的架构&#xff0c;所以分类使用的是resNet 本文详细介绍了三种不同的方法来训练卷积神经网络进行 CIFAR-10 图…

OPPO Find N5折叠手机:创新与实用的完美融合,FPC应用展现科技魅力【新立电子】

OPPO Find N5作为2025年新出世的折叠手机&#xff0c;以其卓越的设计、强大的性能以及创新的技术&#xff0c;为消费者带来了全新的使用体验。FPC&#xff08;柔性电路板&#xff09;在其中的运用&#xff0c;也进一步提升了手机的整体性能和用户体验。 OPPO Find N5的最大亮点…

【AD】PCB增加相关图层——以机械层为例

问题&#xff1a;图中PCB仅有机械层1和机械层2&#xff0c;想要在加一个机械层3 解决 1.点击视图—面板—View Configuration&#xff0c;选中机械层右键单击增加层&#xff0c;其他层类似

测试用例总结

一、通用测试用例八要素   1、用例编号&#xff1b;    2、测试项目&#xff1b;   3、测试标题&#xff1b; 4、重要级别&#xff1b;    5、预置条件&#xff1b;    6、测试输入&#xff1b;    7、操作步骤&#xff1b;    8、预期输出 二、具体分析通…

不用写代码,批量下载今日头条文章导出excel和pdf

前几天有人问我怎么批量抓取今日头条某个号的所有文章数据&#xff0c;需要文章链接&#xff0c;标题和时间&#xff0c;但是不会写代码&#xff0c;于是我写了个简单的教程 这里以渤海小吏为例 首先用edge浏览器安装web-scraper浏览器扩展 然后打开浏览器控制台&#xff0c;找…

Starrocks 写入报错 primary key memory usage exceeds the limit

背景 本文基于 StarRocks 3.3.5 单个Starrocks BE配置是 16CU 32GB 在Flink Yaml CDC 任务往 Starrocks写数据的过程中&#xff0c;突然遇到了primary key memory usage exceeds the limit 问题&#xff0c;具体如下&#xff1a; java.lang.RuntimeException: com.starrocks.…

利用Adobe Acrobat 实现PPT中图片分辨率的提升

1. 下载适用于 Windows 的 64 位 Acrobat 注册方式参考&#xff1a;https://ca.whu.edu.cn/knowledge.html?type1 2. 将ppt中需要提高分辨率的图片复制粘贴到新建的pptx问价中&#xff0c;然后执行“文件—>导出---->创建PDF、XPS文档” 3. 我们会发现保存下来的distrib…

【Python爬虫】爬取公共交通路网数据

程序来自于Github&#xff0c;以下这篇博客作为完整的学习记录&#xff0c;也callback上一篇爬取公共交通站点的博文。 Bardbo/get_bus_lines_and_stations_data_from_gaode: 这个项目是基于高德开放平台和公交网获取公交线路及站点数据&#xff0c;并生成shp文件&#xff0c;…

VUE_使用Vite构建vue项目

创建项目 // 安装vite npm install vite// 创建名为vite-app的项目 npm create vite vite-app --template vue// 到项目目录 cd vite-app// 安装依赖 npm install// 运行项目 npm run dev// 打包 npm run build// 打包预览 npm run serve 增加路由 // 安装路由 npm add vue-r…

ctf网络安全赛题

CTF简介 CTF&#xff08;Capture The Flag&#xff09;中文一般译作夺旗赛&#xff0c;在网络安全领域中指的是网络安全技术人员之间进行技术竞技的一种比赛形式。CTF起源于1996年DEFCON全球黑客大会&#xff0c;以代替之前黑客们通过互相发起真实攻击进行技术比拼的方式。发展…

性能测试监控工具jmeter+grafana

1、什么是性能测试监控体系&#xff1f; 为什么要有监控体系&#xff1f; 原因&#xff1a; 1、项目-日益复杂&#xff08;内部除了代码外&#xff0c;还有中间件&#xff0c;数据库&#xff09; 2、一个系统&#xff0c;背后可能有多个软/硬件组合支撑&#xff0c;影响性能的因…

LabVIEW基于IMAQ实现直线边缘检测

本程序基于 NI Vision Development 模块&#xff0c;通过 IMAQ Find Straight Edges 函数&#xff0c;在指定 ROI&#xff08;感兴趣区域&#xff09; 内检测多条直线边缘。用户可 动态调整检测参数 或 自定义ROI&#xff0c;实时观察识别效果&#xff0c;适用于 高精度视觉检测…

一周学会Flask3 Python Web开发-在模板中渲染WTForms表单视图函数里获取表单数据

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 为了能够在模板中渲染表单&#xff0c;我们需要把表单类实例传入模板。首先在视图函数里实例化表单类LoginForm&#xff0c;然…

小红书湖仓架构的跃迁之路

作者&#xff1a;李鹏霖(丁典)&#xff0c;小红书-研发工程师&#xff0c;StarRocks Contributor & Apache Impala Committer 本文整理自小红书工程师在 StarRocks 年度峰会上的分享&#xff0c;介绍了小红书自助分析平台中&#xff0c;StarRocks 与 Iceberg 结合后&#x…

数据结构第五节:排序

1.常见的排序算法 插入排序&#xff1a;直接插入排序、希尔排序 选择排序&#xff1a;直接选择排序、堆排序 交换排序&#xff1a;冒泡排序、快速排序 归并排序&#xff1a;归并排序 排序的接口实现&#xff1a; // 1. 直接插入排序 void InsertSort(int* a, int n); // 2. 希…

C++发展

目录 ​编辑C 的发展总结&#xff1a;​编辑 1. C 的早期发展&#xff08;1979-1985&#xff09; 2. C 标准化过程&#xff08;1985-1998&#xff09; 3. C 标准演化&#xff08;2003-2011&#xff09; 4. C11&#xff08;2011年&#xff09; 5. C14&#xff08;2014年&a…