Oracle-savepoint相关

总结:在同一个会话下,如果savepoint的名称相同,新的savepoint则会覆盖旧的savepoint,在不同的会话下,savepoint的名称相同,不会相互影响。
为了避免savepoint名称相同,可以在建立savepoint名称时使用时间戳拼接

经过验证,在不同的session使用相同名称的savepoint,也不会互相影响。

session1

INSERT INTO your_table (column1) VALUES ('s1-value1');
SAVEPOINT sp1;INSERT INTO your_table (column1) VALUES ('s1-value2');
SAVEPOINT sp2;INSERT INTO your_table (column1) VALUES ('s1-value3');
SAVEPOINT sp3;--column1 in ('s1-value1', 's1-value2', 's1-value3')
SELECT * FROM your_table;ROLLBACK WORK TO sp2;--column1 in ('s1-value1', 's1-value2')
SELECT * FROM your_table;

session2

INSERT INTO your_table (column1) VALUES ('s2-value1');
SAVEPOINT sp1;INSERT INTO your_table (column1) VALUES ('s2-value2');
SAVEPOINT sp2;INSERT INTO your_table (column1) VALUES ('s2-value3');
SAVEPOINT sp3;--column1 in ('s2-value1', 's2-value2', 's2-value3')
SELECT * FROM your_table;ROLLBACK WORK TO sp1;--column1 in ('s2-value1')
SELECT * FROM your_table;

经过验证,在同一个session下,相同名称的savepoint,新的savepoint会覆盖旧的savepoint

INSERT INTO your_table (column1) VALUES ('value1');
SAVEPOINT sp1;INSERT INTO your_table (column1) VALUES ('value2');
SAVEPOINT sp1;INSERT INTO your_table (column1) VALUES ('value3');
SAVEPOINT sp2;--column1 in ('value1', 'value2', 'value3')
SELECT * FROM your_table;ROLLBACK WORK TO sp1;--column1 in ('value1', 'value2')
SELECT * FROM your_table;INSERT INTO your_table (column1) VALUES ('value4');
SAVEPOINT sp4;INSERT INTO your_table (column1) VALUES ('value5');
SAVEPOINT sp5;--column1 in ('value1', 'value2', 'value4', 'value5')
SELECT * FROM your_table;ROLLBACK WORK TO sp4;--column1 in ('value1', 'value2', 'value4')
SELECT * FROM your_table;--ORA-01086: 从未在此会话中创建保存点 'SP5' 或者该保存点无效
ROLLBACK WORK TO sp5;--column1 in ('value1', 'value2', 'value4')
SELECT * FROM your_table;

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

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

相关文章

特别提醒:2024年软考连考时间再次调整!

近期,辽宁省发布了今年5月软考考试安排,有以下变化: 高级论文单独考试(2小时),之前是案例和论文一起考,案例剩下的时间可以给论文用,现在是综合和案例一起考,综合剩下的…

菜鸡学习netty源码(一)——ServerBootStrap启动

1.概述 对于初学者而然,写一个netty本地进行测试的Server端和Client端,我们最先接触到的类就是ServerBootstrap和Bootstrap。这两个类都有一个公共的父类就是AbstractBootstrap. 那既然 ServerBootstrap和Bootstrap都有一个公共的分类,那就证明它们两个肯定有很多公共的职…

Redis集群.md

Redis集群 本章是基于 CentOS7 下的 Redis 集群教程,包括: 单机安装RedisRedis主从Redis分片集群 1.单机安装Redis 首先需要安装Redis所需要的依赖: yum install -y gcc tcl然后将课前资料提供的Redis安装包上传到虚拟机的任意目录&#xf…

PHP8.2-xlswriter 扩展

https://pecl.php.net/package/xlswriter ### 进入/root/ cd ~ ### 下载扩展 wget https://pecl.php.net/get/xlswriter-1.5.5.tgz ### 解压扩展 tar -zxvf xlswriter-1.5.5.tgz ### 进入扩展目录 cd xlswriter-1.5.5 ### 查找对应php版本的phpize find / -name phpi…

sh: 1: appimagetool: not found

下载 appimagetool: 首先,访问 AppImageHub 或者 AppImage GitHub releases 页面 查找 appimagetool 的最新版本。 安装 appimagetool: 下载完成后,你将获得一个 .AppImage 文件。你需要将这个文件转换为可执行文件&#xff0c…

如何在CentOS部署青龙面板并实现无公网IP远程访问本地面板

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Java双亲委派机制

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 概述 Java程序在运…

一起长锈:4 默认不可变的变量绑定与引用(从Java与C++转Rust之旅)

讲动人的故事,写懂人的代码 故事梗概:在她所维护的老旧Java系统即将被淘汰的危机边缘,这位在编程中总想快速完事的女程序员,希望能转岗到公司内部使用Rust语言的新项目组,因此开始自学Rust;然而,在掌握了Rust编程知识之后,为了通过Rust项目组的技术面试,使得转岗成功而…

激光雷达仿真代码(matlab)

模拟实车多线激光雷达 clc clear close all %% 一 fileName lidarData_ConstructionRoad.pcap; deviceModel HDL32e; veloReader velodyneFileReader(fileName,deviceModel); %% 二 ptCloudreadFrame(veloReader); %% 三 %设置点云显示的区域 xlimits [-25,45]; yl…

sql优化思路

sql的优化经验 这里解释一下SQL语句的优化的原理 1.指明字段名称,可以尽量使用覆盖索引,避免回表查询,因此可以提高效率 2.字面意思,无需过多赘述。索引就是为了提高查询效率的。 3.图中两条sql直接可以使用union all 或者 uni…

C语言三维数组的创建

#include <stdio.h> int main() { int n 5; // 假设我们想要一个 5x5x5 的三维数组 // 但这样声明是不允许的&#xff0c;因为 n 的值在编译时未知 // int f[n][n][n]; // 错误 // 如果 n 是一个编译时常量&#xff08;例如枚举值或 const 变量&#xff09;&#x…

使用react hooks写一个倒计时功能

先要明确的是&#xff0c;setTimeout函数中执行代码的时间肯定是要大于等于setTimeout时间的&#xff0c;那么就可能出现设定的 1 秒&#xff0c;实际执行却执行了 2 秒的情况&#xff0c;那么我们的实现思路也很简单&#xff0c;每次计算一下setTimeout实际执行的时间&#xf…

羊大师分解,羊奶不为人知的健康奇迹

羊大师分解&#xff0c;羊奶不为人知的健康奇迹 羊奶是一种营养丰富的食品&#xff0c;拥有许多不为人知的健康益处。 益智健脑&#xff1a;羊奶中含有较高的钙、蛋白质、氨基酸、维生素、矿物质、无机盐、核酸等营养成分&#xff0c;这些都对大脑发育及增强智力有很大帮助。…

MySQL mydumper工具

目录 1. mydumper介绍 2. mydumper参数解释 3. 备份例子 3.1 备份全库(未包含其他) 3.2 备份全库(包含其他) 3.3 备份指定数据库(-B或--database) 3.4 导出指定表(-T或--tables-list) 3.5 只导出表结构&#xff0c;不导出表数据(-d或--no-data) 3.6 只导出表数据&#…

iOS 横竖屏的正确打开姿势

一、使用场景概述 一种是在present出来的vc中打开横竖屏 固定只有一个方向&#xff08;横屏的方向&#xff09; 可根据重力感应进行横竖屏 某个特定的push出来的vc中打开横竖屏&#xff08;只能根据重力感应横竖屏&#xff0c;不能设置强制的方向&#xff09; 二、具体代码…

包管理工具npm的安装和使用

包管理工具 管理 包 的应用软件&#xff0c;可以对 包 进行下载 安装&#xff0c;更新&#xff0c;删除&#xff0c;上传 等操作。 借助包管理工具&#xff0c;可以快速开发项目&#xff0c;提升开发效率。 包管理工具是一个通用的概念&#xff0c;很多编程语言都有包管理工…

likeshop多商户单商户商城_likeshop跑腿源码_likeshop物品租赁系统开源版怎么配置小程序对接?

本人是商业用户所以能持续得到最新商业版&#xff0c;今天我说下likeshop里面怎么打包小程序&#xff0c;大家得到程序时候会发现它有admin目录 app目录 server目录 这三个目录分别是做什么呢&#xff1f; 1.admin目录 下面都是架构文件使用得是Node.js打包得&#xff0c;至于…

管道通信与Linux命令的执行-(读书笔记-十三)

|前一个命令的输出作为后一个命令的输入。 在Linux中&#xff0c;|符号是一个管道符号&#xff0c;用于将前一个命令的输出作为后一个命令的输入。这种机制允许你将多个命令组合在一起&#xff0c;以执行复杂的操作。下面是一些基本的例子&#xff1a; 查看当前目录下的文件列…

数据互通新纪元,企业如何实现系统无缝对接?

一、客户介绍 某文化发展有限公司&#xff0c;是一家在二次元文化领域深耕的领先企业&#xff0c;自成立以来&#xff0c;始终致力于为广大二次元爱好者提供丰富多样的正版衍生品和独特的文化体验。作为一家专注于二次元周边产品的公司&#xff0c;该公司拥有全面的产品线&…

网站访问免费升级成 HTTPS——值得收藏

实现HTTPS协议可以分为四个主要步骤&#xff0c;以确保网站数据传输的安全性。以下是简明清晰的流程概述&#xff1a; 1. 申请SSL证书 - SSL证书是实现HTTPS的基础&#xff0c;它包含了网站的身份信息以及公钥等。首先&#xff0c;你需要从受信任的证书颁发机构(CA)申请一个SSL…