Таким образом, у меня есть информация, поступающая в URL GET, которую нужно передать в JSON, а затем сохранить (объединить с увеличением идентификаторов, чтобы она была правильной) в СУБД PostgreSQL. Я написал следующий код, который, похоже, ничего не сохраняет без ошибок:
// Pg initialization
const { Client } = require('pg')
client = new Client({
host: 'localhost',
user: 'postgres',
password: 'passwordhere',
database: 'dbnamehere',
});
const createTableText = `
CREATE EXTENSION IF NOT EXISTS "pgcrypto";
CREATE TEMP TABLE IF NOT EXISTS cases (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
data JSONB
);
`
app.get('/test', async function (req, res) {
data = req.query.data;
console.log(data);
res.status(200).send(data);
// create our temp table
await client.query(createTableText)
//const newUser = { email: 'test@test.com' }
// create a new case
await client.query('INSERT INTO cases(data) VALUES($1)', [data])
const { rows } = await client.query('SELECT * FROM cases')
console.log(rows)
res.end();
});
Мой пакет. json зависимости:
"dependencies": {
"express": "^4.17.1",
"mongoose": "^5.9.9",
"pg": "^8.0.3"
},
"devDependencies": {}
ОБНОВЛЕНИЕ
У меня есть этот код обработки ошибок в конце файла:
// Prints out more detailed errors
if(process.env.NODE_ENV !== 'production') {
process.once('uncaughtException', function(err) {
console.error('FATAL: Uncaught exception.');
console.error(err.stack||err);
setTimeout(function(){
process.exit(1);
}, 100);
});
}
Я также попытался установить npm install express-promise-router
и добавить следующий код, но ошибок не было напечатано:
var router = require('express-promise-router')();
router.use('/test', function (req, res) {
return Promise.reject();
})
UPDATE2 Этот код без его закрытия печатает JSONB, а не как его сохранить?:
const connectionString=urlhere;
const pool = new Pool({
connectionString: connectionString,
})
const client = new Client({
connectionString: connectionString,
})
client.connect()
UPDATE3:
Я удалил асинхронный код и сделал его синхронным. Теперь я получаю следующие сообщения об ошибках:
(node:10860) UnhandledPromiseRejectionWarning: Error: Connection terminated
at Connection.<anonymous> (/path/here/node_mo
dules/pg/lib/client.js:275:34)
at Object.onceWrapper (events.js:299:28)
at Connection.emit (events.js:215:7)
at Socket.<anonymous> (/path/here/node_module
s/pg/lib/connection.js:73:10)
at Socket.emit (events.js:210:5)
at TCP.<anonymous> (net.js:659:12)
(node:10860) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This
error originated either by throwing inside of an async function without a catch
block, or by rejecting a promise which was not handled with .catch(). (rejectio
n id: 1)
(node:10860) [DEP0018] DeprecationWarning: Unhandled promise rejections are depr
ecated. In the future, promise rejections that are not handled will terminate th
e Node.js process with a non-zero exit code.
(node:10860) UnhandledPromiseRejectionWarning: Error: Connection terminated
at Connection.<anonymous> (/path/here/client.js:275:34)
at Object.onceWrapper (events.js:299:28)
at Connection.emit (events.js:215:7)
at Socket.<anonymous> (/path/here/node_module
s/pg/lib/connection.js:73:10)
at Socket.emit (events.js:210:5)
at TCP.<anonymous> (net.js:659:12)
(node:10860) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This
error originated either by throwing inside of an async function without a catch
block, or by rejecting a promise which was not handled with .catch(). (rejectio
n id: 2)
(node:10860) UnhandledPromiseRejectionWarning: Error: Connection terminated
at Connection.<anonymous> (/path/here/node_mo
dules/pg/lib/client.js:275:34)
at Object.onceWrapper (events.js:299:28)
at Connection.emit (events.js:215:7)
at Socket.<anonymous> (/path/here/node_module
s/pg/lib/connection.js:73:10)
at Socket.emit (events.js:210:5)
at TCP.<anonymous> (net.js:659:12)
(node:10860) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This
error originated either by throwing inside of an async function without a catch
block, or by rejecting a promise which was not handled with .catch(). (rejectio
n id: 3)