如何验证连接是否已释放

时间:2017-02-14 18:15:35

标签: javascript jdbc database-connection sqlbase centura

我使用 JDBC 驱动程序连接到我的数据库(由Centura Gupta公司使用名为SQLBase的DBMS制作)。

执行时没有问题(甚至我检查过数据是否已插入到我的数据库中)。

但是后来我执行了一个非常简单的SELECT语句,我收到了这个错误:

TypeError: Cannot read property 'createStatement' of undefined
    at /var/apis/api.test/connections/sqlbase.dposs1.js:86:25
    at JDBC.Pool.reserve (/var/apis/api.test/node_modules/jdbc/lib/pool.js:192:5)
    at Object.getCenturaQuery (/var/apis/api.test/connections/sqlbase.dposs1.js:79:15)
    at Object.verificarPagos (/var/apis/api.test/app/bancos/bancos.model.js:146:20)
    at getFacturas (/var/apis/api.test/app/bancos/bancos.rutas.js:7:18)
    at Layer.handle [as handle_request] (/var/apis/api.test/node_modules/express/lib/router/layer.js:95:5)
    at next (/var/apis/api.test/node_modules/express/lib/router/route.js:131:13)
    at Route.dispatch (/var/apis/api.test/node_modules/express/lib/router/route.js:112:3)
    at Layer.handle [as handle_request] (/var/apis/api.test/node_modules/express/lib/router/layer.js:95:5)
    at /var/apis/api.test/node_modules/express/lib/router/index.js:277:22

我认为发布声明没有正确执行。

我使用此处看到的代码:https://www.npmjs.com/package/jdbc

myConnection.release(connObj, function(err) {
    if (err) {
        console.log(err.message);
    }
});

发布后我仍然拥有这个JSON连接对象(我认为它不应该存在,但它仍然存在):

{
    "uuid": "30271a1a-db99-4ff2-8b6a-5befcbe8fbb4",
    "conn": {
        "_conn": {
            "warnings": null
        },
        "_txniso": [
            "TRANSACTION_NONE",
            "TRANSACTION_READ_UNCOMMITTED",
            "TRANSACTION_READ_COMMITTED",
            null,
            "TRANSACTION_REPEATABLE_READ",
            null,
            null,
            null,
            "TRANSACTION_SERIALIZABLE"
        ]
    },
    "keepalive": false
}

如何在执行SELECT声明之前检查连接是否已成功释放?

我认为问题在于这个JSON连接对象。

也许有帮助:我正在服务器端使用JavaScript和NodeJS进行开发。

1 个答案:

答案 0 :(得分:0)

我不是一个JavaScript人 - 但我是Gupta SQLBase的人,逻辑告诉我你不能运行一个' Select'如果你已经释放了句柄(连接)。 通常,从Gupta自己的工具集中,您将按以下顺序执行: 1)连接手柄 2)(可选)将隔离级别设置为“释放锁定”'或者' Read Committed 1,2或3' 。 3)使用相同的句柄运行更新 4) 使用相同的句柄运行提交 5)使用相同的句柄运行选择 6)(可选)释放句柄(或重复使用)

如果我误解了JavaScript的工作原理,那么只能建议Gupta的工作方式。