Clean up postgres export
This commit is contained in:
parent
3c1e72fbdd
commit
c1f651cb54
@ -5,57 +5,33 @@ export function toPostgres(diagram) {
|
|||||||
const enumStatements = diagram.enums
|
const enumStatements = diagram.enums
|
||||||
.map(
|
.map(
|
||||||
(e) =>
|
(e) =>
|
||||||
`CREATE TYPE "${e.name}" AS ENUM (\n${e.values.map((v) => `\t'${v}'`).join("\n")}\n);`,
|
`CREATE TYPE "${e.name}" AS ENUM (\n${e.values.map((v) => `\t'${v}'`).join(",\n")}\n);`,
|
||||||
|
)
|
||||||
|
.join("\n\n");
|
||||||
|
|
||||||
|
const typeStatements = diagram.types
|
||||||
|
.map(
|
||||||
|
(type) =>
|
||||||
|
`CREATE TYPE ${type.name} AS (\n${type.fields
|
||||||
|
.map((f) => `\t${f.name} ${f.type}`)
|
||||||
|
.join("\n")}\n);\n${
|
||||||
|
type.comment.trim() !== ""
|
||||||
|
? `\nCOMMENT ON TYPE "${type.name}" IS '${type.comment}';\n`
|
||||||
|
: ""
|
||||||
|
}`,
|
||||||
)
|
)
|
||||||
.join("\n");
|
.join("\n");
|
||||||
|
|
||||||
return `${enumStatements}\n${diagram.types.map((type) => {
|
return `${enumStatements}\n\n${typeStatements}\n${diagram.tables
|
||||||
const typeStatements = type.fields
|
|
||||||
.filter((f) => f.type === "ENUM" || f.type === "SET")
|
|
||||||
.map(
|
|
||||||
(f) =>
|
|
||||||
`CREATE TYPE "${f.name}_t" AS ENUM (${f.values
|
|
||||||
.map((v) => `'${v}'`)
|
|
||||||
.join(", ")});\n`,
|
|
||||||
);
|
|
||||||
if (typeStatements.length > 0) {
|
|
||||||
return (
|
|
||||||
typeStatements.join("") +
|
|
||||||
`${
|
|
||||||
type.comment === "" ? "" : `/**\n${type.comment}\n*/\n`
|
|
||||||
}CREATE TYPE ${type.name} AS (\n${type.fields
|
|
||||||
.map((f) => `\t${f.name} ${f.type}`)
|
|
||||||
.join("\n")}\n);`
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
return `${
|
|
||||||
type.comment === "" ? "" : `/**\n${type.comment}\n*/\n`
|
|
||||||
}CREATE TYPE ${type.name} AS (\n${type.fields
|
|
||||||
.map((f) => `\t${f.name} ${f.type}`)
|
|
||||||
.join("\n")}\n);`;
|
|
||||||
}
|
|
||||||
})}\n${diagram.tables
|
|
||||||
.map(
|
.map(
|
||||||
(table) =>
|
(table) =>
|
||||||
`${table.comment === "" ? "" : `/**\n${table.comment}\n*/\n`}${
|
`CREATE TABLE "${table.name}" (\n${table.fields
|
||||||
table.fields.filter((f) => f.type === "ENUM" || f.type === "SET")
|
|
||||||
.length > 0
|
|
||||||
? `${table.fields
|
|
||||||
.filter((f) => f.type === "ENUM" || f.type === "SET")
|
|
||||||
.map(
|
|
||||||
(f) =>
|
|
||||||
`CREATE TYPE "${f.name}_t" AS ENUM (${f.values
|
|
||||||
.map((v) => `'${v}'`)
|
|
||||||
.join(", ")});\n\n`,
|
|
||||||
)}`
|
|
||||||
: ""
|
|
||||||
}CREATE TABLE "${table.name}" (\n${table.fields
|
|
||||||
.map(
|
.map(
|
||||||
(field) =>
|
(field) =>
|
||||||
`${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t"${
|
`${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t"${
|
||||||
field.name
|
field.name
|
||||||
}" ${field.type}${field.notNull ? " NOT NULL" : ""}${
|
}" ${field.type}${field.notNull ? " NOT NULL" : ""}${field.unique ? " UNIQUE" : ""}${
|
||||||
field.default !== ""
|
field.default.trim() !== ""
|
||||||
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
||||||
: ""
|
: ""
|
||||||
}${
|
}${
|
||||||
@ -73,17 +49,19 @@ export function toPostgres(diagram) {
|
|||||||
.join(", ")})`
|
.join(", ")})`
|
||||||
: ""
|
: ""
|
||||||
}\n);\n${
|
}\n);\n${
|
||||||
table.indices.length > 0
|
table.comment.trim() !== ""
|
||||||
? `${table.indices.map(
|
? `\nCOMMENT ON TABLE "${table.name}" IS '${table.comment}';\n`
|
||||||
(i) =>
|
|
||||||
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX "${
|
|
||||||
i.name
|
|
||||||
}"\nON "${table.name}" (${i.fields
|
|
||||||
.map((f) => `"${f}"`)
|
|
||||||
.join(", ")});`,
|
|
||||||
)}`
|
|
||||||
: ""
|
: ""
|
||||||
}`,
|
}${table.indices
|
||||||
|
.map(
|
||||||
|
(i) =>
|
||||||
|
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX "${
|
||||||
|
i.name
|
||||||
|
}"\nON "${table.name}" (${i.fields
|
||||||
|
.map((f) => `"${f}"`)
|
||||||
|
.join(", ")});`,
|
||||||
|
)
|
||||||
|
.join("\n")}\n`,
|
||||||
)
|
)
|
||||||
.join("\n")}\n${diagram.references
|
.join("\n")}\n${diagram.references
|
||||||
.map(
|
.map(
|
||||||
|
Loading…
Reference in New Issue
Block a user