61 lines
1.5 KiB
JavaScript
61 lines
1.5 KiB
JavaScript
// Redshift Column Compiler
|
|
// -------
|
|
|
|
const inherits = require('inherits');
|
|
const ColumnCompiler_PG = require('../../postgres/schema/columncompiler');
|
|
|
|
function ColumnCompiler_Redshift() {
|
|
ColumnCompiler_PG.apply(this, arguments);
|
|
}
|
|
inherits(ColumnCompiler_Redshift, ColumnCompiler_PG);
|
|
|
|
Object.assign(ColumnCompiler_Redshift.prototype, {
|
|
// Types:
|
|
// ------
|
|
bigincrements: 'bigint identity(1,1) primary key not null',
|
|
binary: 'varchar(max)',
|
|
bit(column) {
|
|
return column.length !== false ? `char(${column.length})` : 'char(1)';
|
|
},
|
|
blob: 'varchar(max)',
|
|
enu: 'varchar(255)',
|
|
enum: 'varchar(255)',
|
|
increments: 'integer identity(1,1) primary key not null',
|
|
json: 'varchar(max)',
|
|
jsonb: 'varchar(max)',
|
|
longblob: 'varchar(max)',
|
|
mediumblob: 'varchar(16777218)',
|
|
set: 'text',
|
|
text: 'varchar(max)',
|
|
datetime(without) {
|
|
return without ? 'timestamp' : 'timestamptz';
|
|
},
|
|
timestamp(without) {
|
|
return without ? 'timestamp' : 'timestamptz';
|
|
},
|
|
tinyblob: 'varchar(256)',
|
|
uuid: 'char(36)',
|
|
varbinary: 'varchar(max)',
|
|
bigint: 'bigint',
|
|
bool: 'boolean',
|
|
double: 'double precision',
|
|
floating: 'real',
|
|
smallint: 'smallint',
|
|
tinyint: 'smallint',
|
|
|
|
// Modifiers:
|
|
// ------
|
|
comment(comment) {
|
|
this.pushAdditional(function() {
|
|
this.pushQuery(
|
|
`comment on column ${this.tableCompiler.tableName()}.` +
|
|
this.formatter.wrap(this.args[0]) +
|
|
' is ' +
|
|
(comment ? `'${comment}'` : 'NULL')
|
|
);
|
|
}, comment);
|
|
},
|
|
});
|
|
|
|
module.exports = ColumnCompiler_Redshift;
|