node连接oracle数据库,更新数据后,数据库中不生效问题

栏目: 数据库 · 发布时间: 6年前

内容简介:线上数据更新oracle中表数据时,一切都是正常的,但是本地断点测试的时候,实际数据库中未发生改变。大概如下,更新一张表中的内容,大致如下:并且他返回了一个对象,显示rowsaffected是1,也就是一行受影响。但是此时取数据库看时,并未生效。

线上数据更新oracle中表数据时,一切都是正常的,但是本地断点测试的时候,实际数据库中未发生改变。

问题

大概如下,更新一张表中的内容,大致如下:

connection.execute( 'UPDATE table1 SET key = 123 WHERE id = 11')

并且他返回了一个对象,显示rowsaffected是1,也就是一行受影响。但是此时取数据库看时,并未生效。

处理方法

查了很久,还以为原先的是正常的,咋突然就不行了呢?后询问后端人员,更改数据库时,可能需要commit下。而我最后会在循环之后调用一个存储过程,该存储过程中有commit,故正常跑没有问题。而断点或没有执行存储过程时,都无法在数据库中生效。

所以得出结论,更新表时需要commit下,当然node-oracledb也提供了方法:

const oracledb = require('oracledb');
oracledb.autoCommit = true;

设置自动提交后,问题就可以解决了。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

网飞传奇

网飞传奇

[美]吉娜·基廷 / 谭永乐 / 中信出版社 / 2014-1-1 / 42

飞的历史充满了传奇色彩,它的崛起伴随着复杂斗争、幸运转折、个人背叛……它自身的历史比它出租的那些电影还要更富有戏剧性。网飞在1997年建立,而建立的原因仅仅是因为创始人伦道夫和哈斯廷斯没有按时归还租借的DVD,还要缴纳因此而产生的滞纳金。 1999年,网飞公司摒弃了百视达的“每片付租”模式,转而采用了一种订阅模式:用户只需要支付固定费用,就能尽情租片观赏,免去了到期还片日、滞纳金、运费和手续......一起来看看 《网飞传奇》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具