Merge pull request #252 from csc530/main

Fix export for enum and set types for mysql
This commit is contained in:
1ilit 2024-10-11 15:08:10 +04:00 committed by GitHub
commit 7d3d1dd9e2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 46 additions and 64 deletions

View File

@ -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")}`;
} }

View File

@ -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")}`;
} }