0.0.8 • Published 8 years ago
i-are-dba v0.0.8
i-are-dba (in alpha)
Warning: the interface is likely to change during the early stages of development.
I are DBA produces CREATE TABLE SQL statements based on the data to be written to the table.
Supported RDBMS engines:
- Redshift
Example usage
/* example usage - run node example.js to try yourself (uses Node.js 6.3) */
const makeCreateTableStatement = require('./src/create-table');
const data = [
['name', 'date_of_birth', 'height', 'num_wins', 'undefeated'],
['Catherine', '1965-08-01', '1.56', '30', 'no'],
['John', '1988-12-21', '1.86', '12', 'yes'],
['Anabelle', '1973-02-13', '1.56', '6', true],
['Joan', '2001-09-11', '1.56', 15, 0],
];
const createTableStatement = makeCreateTableStatement('players', data);
console.log(createTableStatement);
output:
CREATE TABLE players (
name VARCHAR(9),
date_of_birth DATE,
height DECIMAL(4,2),
num_wins SMALLINT,
undefeated BOOLEAN
)
Known issues
Due to a shortcoming in node, it is only possible to make the most of the BIGINTEGER type if you pass large numbers as type String
. This affects numbers above 9007199254740991 or below -9007199254740991.
Because Redshift does not support the logical maximum value for DECIMAL(19,N)
, all DECIMAL
values have a precision one greater than is (usually) strictly necessary. Work to eek out every last byte of performance might be done in the future.