Merge pull request #252 from csc530/main
Fix export for enum and set types for mysql
This commit is contained in:
commit
7d3d1dd9e2
@ -9,33 +9,27 @@ export function toMariaDB(diagram) {
|
|||||||
`CREATE OR REPLACE TABLE \`${table.name}\` (\n${table.fields
|
`CREATE OR REPLACE TABLE \`${table.name}\` (\n${table.fields
|
||||||
.map(
|
.map(
|
||||||
(field) =>
|
(field) =>
|
||||||
`\t\`${
|
`\t\`${field.name
|
||||||
field.name
|
}\` ${field.type}${field.values ? "(" + field.values.map(value => "'" + value + "'").join(", ") + ")" : ""}${field.unsigned ? " UNSIGNED" : ""}${field.notNull ? " NOT NULL" : ""}${field.increment ? " AUTO_INCREMENT" : ""
|
||||||
}\` ${field.type}${field.unsigned ? " UNSIGNED" : ""}${field.notNull ? " NOT NULL" : ""}${
|
}${field.unique ? " UNIQUE" : ""}${field.default !== ""
|
||||||
field.increment ? " AUTO_INCREMENT" : ""
|
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
||||||
}${field.unique ? " UNIQUE" : ""}${
|
: ""
|
||||||
field.default !== ""
|
}${field.check === "" ||
|
||||||
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
|
||||||
: ""
|
|
||||||
}${
|
|
||||||
field.check === "" ||
|
|
||||||
!dbToTypes[diagram.database][field.type].hasCheck
|
!dbToTypes[diagram.database][field.type].hasCheck
|
||||||
? ""
|
? ""
|
||||||
: ` CHECK(${field.check})`
|
: ` CHECK(${field.check})`
|
||||||
}${field.comment ? ` COMMENT '${field.comment}'` : ""}`,
|
}${field.comment ? ` COMMENT '${field.comment}'` : ""}`,
|
||||||
)
|
)
|
||||||
.join(",\n")}${
|
.join(",\n")}${table.fields.filter((f) => f.primary).length > 0
|
||||||
table.fields.filter((f) => f.primary).length > 0
|
? `,\n\tPRIMARY KEY(${table.fields
|
||||||
? `,\n\tPRIMARY KEY(${table.fields
|
.filter((f) => f.primary)
|
||||||
.filter((f) => f.primary)
|
.map((f) => `\`${f.name}\``)
|
||||||
.map((f) => `\`${f.name}\``)
|
.join(", ")})`
|
||||||
.join(", ")})`
|
: ""
|
||||||
: ""
|
|
||||||
}\n)${table.comment ? ` COMMENT='${table.comment}'` : ""};${`\n${table.indices
|
}\n)${table.comment ? ` COMMENT='${table.comment}'` : ""};${`\n${table.indices
|
||||||
.map(
|
.map(
|
||||||
(i) =>
|
(i) =>
|
||||||
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX \`${
|
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX \`${i.name
|
||||||
i.name
|
|
||||||
}\`\nON \`${table.name}\` (${i.fields
|
}\`\nON \`${table.name}\` (${i.fields
|
||||||
.map((f) => `\`${f}\``)
|
.map((f) => `\`${f}\``)
|
||||||
.join(", ")});`,
|
.join(", ")});`,
|
||||||
@ -43,15 +37,12 @@ export function toMariaDB(diagram) {
|
|||||||
.join("")}`}`,
|
.join("")}`}`,
|
||||||
)
|
)
|
||||||
.join("\n")}\n${diagram.references
|
.join("\n")}\n${diagram.references
|
||||||
.map(
|
.map(
|
||||||
(r) =>
|
(r) =>
|
||||||
`ALTER TABLE \`${
|
`ALTER TABLE \`${diagram.tables[r.startTableId].name
|
||||||
diagram.tables[r.startTableId].name
|
}\`\nADD FOREIGN KEY(\`${diagram.tables[r.startTableId].fields[r.startFieldId].name
|
||||||
}\`\nADD FOREIGN KEY(\`${
|
}\`) REFERENCES \`${diagram.tables[r.endTableId].name}\`(\`${diagram.tables[r.endTableId].fields[r.endFieldId].name
|
||||||
diagram.tables[r.startTableId].fields[r.startFieldId].name
|
}\`)\nON UPDATE ${r.updateConstraint.toUpperCase()} ON DELETE ${r.deleteConstraint.toUpperCase()};`,
|
||||||
}\`) REFERENCES \`${diagram.tables[r.endTableId].name}\`(\`${
|
)
|
||||||
diagram.tables[r.endTableId].fields[r.endFieldId].name
|
.join("\n")}`;
|
||||||
}\`)\nON UPDATE ${r.updateConstraint.toUpperCase()} ON DELETE ${r.deleteConstraint.toUpperCase()};`,
|
|
||||||
)
|
|
||||||
.join("\n")}`;
|
|
||||||
}
|
}
|
||||||
|
@ -9,33 +9,27 @@ export function toMySQL(diagram) {
|
|||||||
`CREATE TABLE \`${table.name}\` (\n${table.fields
|
`CREATE TABLE \`${table.name}\` (\n${table.fields
|
||||||
.map(
|
.map(
|
||||||
(field) =>
|
(field) =>
|
||||||
`\t\`${field.name}\` ${field.type}${field.unsigned ? " UNSIGNED" : ""}${field.size !== undefined && field.size !== "" ? "(" + field.size + ")" : ""}${
|
`\t\`${field.name}\` ${field.type}${field.values ? "(" + field.values.map(value => "'" + value + "'").join(", ") + ")" : ""}${field.unsigned ? " UNSIGNED" : ""}${field.size !== undefined && field.size !== "" ? "(" + field.size + ")" : ""}${field.notNull ? " NOT NULL" : ""
|
||||||
field.notNull ? " NOT NULL" : ""
|
}${field.increment ? " AUTO_INCREMENT" : ""
|
||||||
}${
|
}${field.unique ? " UNIQUE" : ""}${field.default !== ""
|
||||||
field.increment ? " AUTO_INCREMENT" : ""
|
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
||||||
}${field.unique ? " UNIQUE" : ""}${
|
: ""
|
||||||
field.default !== ""
|
}${field.check === "" ||
|
||||||
? ` DEFAULT ${parseDefault(field, diagram.database)}`
|
|
||||||
: ""
|
|
||||||
}${
|
|
||||||
field.check === "" ||
|
|
||||||
!dbToTypes[diagram.database][field.type].hasCheck
|
!dbToTypes[diagram.database][field.type].hasCheck
|
||||||
? ""
|
? ""
|
||||||
: ` CHECK(${field.check})`
|
: ` CHECK(${field.check})`
|
||||||
}${field.comment ? ` COMMENT '${field.comment}'` : ""}`,
|
}${field.comment ? ` COMMENT '${field.comment}'` : ""}`,
|
||||||
)
|
)
|
||||||
.join(",\n")}${
|
.join(",\n")}${table.fields.filter((f) => f.primary).length > 0
|
||||||
table.fields.filter((f) => f.primary).length > 0
|
? `,\n\tPRIMARY KEY(${table.fields
|
||||||
? `,\n\tPRIMARY KEY(${table.fields
|
.filter((f) => f.primary)
|
||||||
.filter((f) => f.primary)
|
.map((f) => `\`${f.name}\``)
|
||||||
.map((f) => `\`${f.name}\``)
|
.join(", ")})`
|
||||||
.join(", ")})`
|
: ""
|
||||||
: ""
|
|
||||||
}\n)${table.comment ? ` COMMENT='${table.comment}'` : ""};\n${`\n${table.indices
|
}\n)${table.comment ? ` COMMENT='${table.comment}'` : ""};\n${`\n${table.indices
|
||||||
.map(
|
.map(
|
||||||
(i) =>
|
(i) =>
|
||||||
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX \`${
|
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX \`${i.name
|
||||||
i.name
|
|
||||||
}\`\nON \`${table.name}\` (${i.fields
|
}\`\nON \`${table.name}\` (${i.fields
|
||||||
.map((f) => `\`${f}\``)
|
.map((f) => `\`${f}\``)
|
||||||
.join(", ")});`,
|
.join(", ")});`,
|
||||||
@ -43,15 +37,12 @@ export function toMySQL(diagram) {
|
|||||||
.join("")}`}`,
|
.join("")}`}`,
|
||||||
)
|
)
|
||||||
.join("\n")}\n${diagram.references
|
.join("\n")}\n${diagram.references
|
||||||
.map(
|
.map(
|
||||||
(r) =>
|
(r) =>
|
||||||
`ALTER TABLE \`${
|
`ALTER TABLE \`${diagram.tables[r.startTableId].name
|
||||||
diagram.tables[r.startTableId].name
|
}\`\nADD FOREIGN KEY(\`${diagram.tables[r.startTableId].fields[r.startFieldId].name
|
||||||
}\`\nADD FOREIGN KEY(\`${
|
}\`) REFERENCES \`${diagram.tables[r.endTableId].name}\`(\`${diagram.tables[r.endTableId].fields[r.endFieldId].name
|
||||||
diagram.tables[r.startTableId].fields[r.startFieldId].name
|
}\`)\nON UPDATE ${r.updateConstraint.toUpperCase()} ON DELETE ${r.deleteConstraint.toUpperCase()};`,
|
||||||
}\`) REFERENCES \`${diagram.tables[r.endTableId].name}\`(\`${
|
)
|
||||||
diagram.tables[r.endTableId].fields[r.endFieldId].name
|
.join("\n")}`;
|
||||||
}\`)\nON UPDATE ${r.updateConstraint.toUpperCase()} ON DELETE ${r.deleteConstraint.toUpperCase()};`,
|
|
||||||
)
|
|
||||||
.join("\n")}`;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user