OracleCommand执行ExecuteNonQuery出现程序挂起现象

2024-02-15 17:48

本文主要是介绍OracleCommand执行ExecuteNonQuery出现程序挂起现象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

string sql = "INSERT INTO TempTable (A, B, C) VALUES ('2222222', '1111111', 'RRR')";//A为主键
OracleCommand cmd = new OracleCommand(sql, connection);
cmd.ExecuteNonQuery();

在执行这段代码的时候,第一次插入没有成功,当Stop Debug再重新启动的时候,发现程序运行到cmd.ExecuteNonQuery的时候就卡住不动了。造成这个的原因是Oracle的block机制。

If session "A" inserts a row in a table with a primary key, session "A" will block ANY other session attempting to insert the same primary key until session "A" commits or rolls back the insert. All other attempts to insert will "hang".

此时我在代码中把sql语句主键2222222换成33333333,那么就能顺利插入。说明只有在相同的主键情况下,这个操作才会被block. 因为以前插入2222222的时候,程序意外结束,但是对于Oracle端事务并没有提交或者回滚,所以就锁定了这一个主键。注意,仅仅是这一个值的主键。

这里还有一个问题,就是现在我打开SQL Developer,执行插入2222222的主键语句,会顺利的执行完成,不发生卡住现在,而用代码执行SQL语句还是会发生卡住现象。但是我重启VS,新建一个项目,写入这些代码,也相当于另外的一个程序来执行这个插入语句,也是会有卡住现象。可能跟使用的.net provider有关?因为使用的是同一个Provider,所以卡住。因为SQL Developer没有使用这个provider,所以不会卡住?这只是一个猜测。

这种lock叫做TMlock,也叫row transaction lock, 可以使用SQL语句查看是否有这种lock

SELECT sid, id1 FROM v$lock WHERE TYPE='TM'

SID ID1
76 14197

SELECT * FROM dba_objects WHERE object_id = 14197;

OBJECT_NAME                                                                                                                    
--------------------------------------------------------------------------------------------------------------------------------
TemTable


如何解除这个TM lock?row transaction lock

在SQL Developer UI执行一个Commit命令就行了。

这篇关于OracleCommand执行ExecuteNonQuery出现程序挂起现象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/712085

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo