Instr带来的BUG
昨天下午技术部JAVA开发人员报告说 线上数据库无法删除数据,要我查看下数据库是否有什么锁住. 我还以为是死锁或者是什么阻塞之类了. 折腾下没有发现! 叫它把语句发来,他就把表名,而且是截图发过来的! 根据表名去找 删除的语句 SELECT SQL_ID,PIECE,SQL_TEXTF
昨天下午技术部JAVA开发人员报告说 线上数据库无法删除数据,要我查看下数据库是否有什么锁住. 我还以为是死锁或者是什么阻塞之类了.
折腾下没有发现!
叫它把语句发来,他就把表名,而且是截图发过来的!
根据表名去找 删除的语句
SELECT SQL_ID,PIECE,SQL_TEXT FROM V$SQLTEXT_WITH_NEWLINES WHERE SQL_ID IN( SELECT SQL_ID FROM V$SQLTEXT_WITH_NEWLINES WHERE SQL_TEXT LIKE '%table_name%') ORDER BY SQL_ID,PIECE;
select * from v$sql_bind_capture where sql_id in ('fpkt91ujqu853');
gquw3xgbqvu13: delete from paynum p WHERE INSTR(:1,','||PL_ID||',')>0 2014-3-12 17:44:13 ,3251,3250,3248,3247, 2014-3-11 11:56:18 ,3249, b5yjgrqx6j2dm: delete from paynum paynum WHERE INSTR(:1,''||PL_ID||'')>0 2014-3-13 17:45:02 ,3319, fpkt91ujqu853: delete from paynum_ELEMENT e WHERE INSTR(:1,','||e.ple_pl_id||',')>0 2014-3-13 17:45:02 ,3319, 其中 pay_element 是关联表 该表有paynum的外键 就是这个外键约束报的错误.
从上面看 删除paynum有两条不同的SQL语句 第一个估计是旧的,第二个是最近上线的.
根据变量的值 可以了解 先删除 关联表 输入变量 ',3319,' 然后删除PAYNUM表 同样输入变量',3319,'
我们同样可以看出来参数:1 不仅可以输入单个变量值,还可以输入一串变量的值 比如 ',3251,3250,3248,3247,'
从数据表查询3319值的记录 关联表 paynum_ELEMENT 已经被删除,而 PAYNUM 还存在 !
我们综合下
delete from paynum paynum WHERE INSTR(',3319,',''||PL_ID||'') > 0
对于这样的语句 做为地球普通人的我实在难以理解和猜透. 通过自身努力终于理解了它,来之汪星的写法!
select pl_id, INSTR(',3319,',''||PL_ID||'') from paynum;
我测试下 它确实能删除记录. 不过线上的行为就表现如下
PL_ID INSTR('3319',''||PL_ID||'') 1 3 31 2 33 1 331 1 3319 1 2279 0 2282 0 2281 0 2280 0
(源字符串, 目标字符串, 起始位置, 匹配序号)
在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始
发现了什么没?对没错误 狗屎的家伙 居然写反了 INSTR(',3319,',''||PL_ID||'')
正常写法是INSTR(''||PL_ID||'', ',3319,')
正常设计是:
delete from paynum paynum where paynum.pl_id=to_number(:?)

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题











Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

Java是热门编程语言,适合初学者和经验丰富的开发者学习。本教程从基础概念出发,逐步深入讲解高级主题。安装Java开发工具包后,可通过创建简单的“Hello,World!”程序实践编程。理解代码后,使用命令提示符编译并运行程序,控制台上将输出“Hello,World!”。学习Java开启了编程之旅,随着掌握程度加深,可创建更复杂的应用程序。
