-
Notifications
You must be signed in to change notification settings - Fork 46
Expand file tree
/
Copy pathconnection_pooling.js
More file actions
108 lines (91 loc) · 3.08 KB
/
connection_pooling.js
File metadata and controls
108 lines (91 loc) · 3.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
var Redshift = require('../index.js');
var client = {
user: 'karthikeyan_b',
database: 'gti_dw',
password: 'KarthikeyanB2021',
port: '5439',
host: 'gti-dw-dev.cskoof8zzowd.us-east-1.redshift.amazonaws.com'
};
var redshift = new Redshift(client,{rawConnection:true}); //no need to call connect(), without rawConnection, it automatically connects
module.exports.GetList = function(req,res) {
// using callbacks
try {
redshift.connect();
console.log("redshift Query");
redshift.query('SELECT * FROM "form_user_details"', { raw: true }, function (err, data) {
if (err) {
console.log(err)
res.status(400).send(err);
} else {
console.log(data);
res.status(200).send(data);
// if you wasnt to close client pool, uncomment redshift.close() line
// but you won't be able to make subsequent calls because connection is terminated
redshift.close();
}
});
} catch (error) {
res.status(400).send(error);
}
}
// using promises
module.exports.GetListwithPromises = function(req,res) {
// using callbacks
try {
// var redshift = new Redshift(client);
redshift.connect(function(err){ //create connection manually
if (err) {
res.status(401).send(''+ err);
} else {
console.log('redshift connected succesfully');
redshift.query('SELECT * FROM form_user_details', {raw: true}).then(function(data){ //query redshift
console.log(data);
res.status(200).send(data);
redshift.close();
}, function(err){
res.status(400).send(err);
});
}
});
} catch (error) {
res.status(401).send('Error - ' + error);
}
}
module.exports.GetListwithRawQuery = function(req,res) {
// using callbacks
try {
// var redshift = new Redshift(client);
redshift.rawQuery(`SELECT * FROM "form_user_details"`, {raw: true}).then(function(data){
console.log(data);
})
.catch(function(err){
console.log(err);
});
} catch (error) {
res.status(401).send('Error - ' + error);
}
}
// const query = `select * from webapp.partner where is_active = true`;
module.exports.executeQuery = async function(req,res) {
try {
var query = await redshift.createQuery(req.query);
console.log(query);
redshift.connectRedShift(async function (dbConnection) {
const date1 = new Date().getTime();
const connection = await dbConnection;
const result = await connection.query(query);
const date2 = new Date().getTime();
const durationMs = date2 - date1;
const durationSeconds = Math.round(durationMs / 1000);
let dataLength = 0;
if (result && result.length) dataLength = result.length;
console.log(
`[Redshift] [${durationMs}ms] [${durationSeconds}s] [${dataLength.toLocaleString()} records] ${query}`
);
return res.status(200).send({ "query": query, "result": result });
})
} catch (e) {
console.error(`Error executing query: ${query} Error: ${e.message}`);
res.status(401).send(e);
}
}