drawDB/src/utils/exportSQL/postgres.js

77 lines
2.6 KiB
JavaScript
Raw Normal View History

2024-06-22 09:13:44 +08:00
import { dbToTypes } from "../../data/datatypes";
import { parseDefault } from "./shared";
export function toPostgres(diagram) {
2024-07-03 04:26:45 +08:00
const enumStatements = diagram.enums
.map(
(e) =>
2024-07-03 05:33:23 +08:00
`CREATE TYPE "${e.name}" AS ENUM (\n${e.values.map((v) => `\t'${v}'`).join(",\n")}\n);`,
2024-07-03 04:26:45 +08:00
)
2024-07-03 05:33:23 +08:00
.join("\n\n");
2024-07-03 04:26:45 +08:00
2024-07-03 05:33:23 +08:00
const typeStatements = diagram.types
.map(
(type) =>
`CREATE TYPE ${type.name} AS (\n${type.fields
2024-06-22 09:13:44 +08:00
.map((f) => `\t${f.name} ${f.type}`)
2024-07-03 05:33:23 +08:00
.join("\n")}\n);\n${
type.comment.trim() !== ""
? `\nCOMMENT ON TYPE "${type.name}" IS '${type.comment}';\n`
: ""
}`,
)
.join("\n");
return `${enumStatements}\n\n${typeStatements}\n${diagram.tables
2024-06-22 09:13:44 +08:00
.map(
(table) =>
2024-07-03 05:33:23 +08:00
`CREATE TABLE "${table.name}" (\n${table.fields
2024-06-22 09:13:44 +08:00
.map(
(field) =>
`${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t"${
field.name
2024-07-06 03:28:44 +08:00
}" ${field.type}${field.isArray ? " ARRAY" : ""}${field.notNull ? " NOT NULL" : ""}${field.unique ? " UNIQUE" : ""}${
2024-07-03 05:33:23 +08:00
field.default.trim() !== ""
2024-06-22 09:13:44 +08:00
? ` DEFAULT ${parseDefault(field, diagram.database)}`
: ""
}${
field.check === "" ||
!dbToTypes[diagram.database][field.type].hasCheck
? ""
: ` CHECK(${field.check})`
}`,
)
.join(",\n")}${
table.fields.filter((f) => f.primary).length > 0
? `,\n\tPRIMARY KEY(${table.fields
.filter((f) => f.primary)
.map((f) => `"${f.name}"`)
.join(", ")})`
: ""
}\n);\n${
2024-07-03 05:33:23 +08:00
table.comment.trim() !== ""
? `\nCOMMENT ON TABLE "${table.name}" IS '${table.comment}';\n`
2024-06-22 09:13:44 +08:00
: ""
2024-07-03 05:33:23 +08:00
}${table.indices
.map(
(i) =>
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX "${
i.name
}"\nON "${table.name}" (${i.fields
.map((f) => `"${f}"`)
.join(", ")});`,
)
.join("\n")}\n`,
2024-06-22 09:13:44 +08:00
)
.join("\n")}\n${diagram.references
.map(
(r) =>
`ALTER TABLE "${diagram.tables[r.startTableId].name}"\nADD FOREIGN KEY("${
diagram.tables[r.startTableId].fields[r.startFieldId].name
}") REFERENCES "${diagram.tables[r.endTableId].name}"("${
diagram.tables[r.endTableId].fields[r.endFieldId].name
}")\nON UPDATE ${r.updateConstraint.toUpperCase()} ON DELETE ${r.deleteConstraint.toUpperCase()};`,
)
.join("\n")}`;
}