内容简介:线上数据更新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;
设置自动提交后,问题就可以解决了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 4 万字全面掌握数据库、数据仓库、数据集市、数据湖、数据中台
- Python3爬虫数据入数据库---把爬取到的数据存到数据库,带数据库去重功能
- Oracle数据库查询重复数据及删除重复数据方法
- sqlserver数据库获取数据库信息
- 从大数据到数据库
- mybatis从数据库中取数据且分组,返回分组数据
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。