-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathbasic-typescript-odbc-connectivity-readme.ts
More file actions
65 lines (54 loc) · 1.39 KB
/
basic-typescript-odbc-connectivity-readme.ts
File metadata and controls
65 lines (54 loc) · 1.39 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
/**
* basic-odbc-query.ts
*
* Executes a single SQL or SPARQL query provided at initialization time.
*
* Usage:
* node basic-odbc-query.js "<QUERY>"
* node basic-odbc-query.js "<QUERY>" [DSN] [UID] [PWD]
*
* Examples:
* node basic-odbc-query.js "SELECT 1"
*
* node basic-odbc-query.js \
* "SPARQL SELECT * WHERE { ?s ?p ?o } LIMIT 10" \
* MyVirtuosoDSN dba dba
*/
import * as odbc from 'odbc';
/*
* Defaults
*/
const DEFAULT_DSN = 'MyVirtuosoDSN';
const DEFAULT_UID = 'dba';
const DEFAULT_PWD = 'dba';
/*
* CLI arguments
* argv[2] = query (required)
* argv[3] = DSN
* argv[4] = UID
* argv[5] = PWD
*/
const [, , query, cliDsn, cliUid, cliPwd] = process.argv;
if (!query) {
console.error('Error: query argument is required.');
process.exit(1);
}
const DSN = cliDsn || DEFAULT_DSN;
const UID = cliUid || DEFAULT_UID;
const PWD = cliPwd || DEFAULT_PWD;
const connectionString = `DSN=${DSN};UID=${UID};PWD=${PWD};`;
async function main() {
try {
console.log(`Connecting via DSN='${DSN}' as UID='${UID}'`);
console.log(`Executing query:\n${query}\n`);
const connection = await odbc.connect(connectionString);
const result = await connection.query(query);
console.log('Result:');
console.dir(result, { depth: null });
await connection.close();
} catch (err) {
console.error('Execution failed:', err);
process.exit(1);
}
}
main();