mirror of
https://github.com/Fabio286/antares.git
synced 2025-06-05 21:59:22 +02:00
perf: improved the way how field default value are handled
This commit is contained in:
@@ -84,7 +84,7 @@ This is a roadmap with major features will come in near future.
|
|||||||
|
|
||||||
- [ ] Windows
|
- [ ] Windows
|
||||||
- [x] Linux
|
- [x] Linux
|
||||||
- [x] MacOS
|
- [ ] MacOS
|
||||||
|
|
||||||
## Translations
|
## Translations
|
||||||
|
|
||||||
|
@@ -32,8 +32,7 @@
|
|||||||
"target": {
|
"target": {
|
||||||
"target": "default",
|
"target": "default",
|
||||||
"arch": [
|
"arch": [
|
||||||
"x64",
|
"x64"
|
||||||
"arm64"
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -132,4 +131,4 @@
|
|||||||
"vue-template-compiler": "^2.6.12",
|
"vue-template-compiler": "^2.6.12",
|
||||||
"webpack": "^4.46.0"
|
"webpack": "^4.46.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -309,24 +309,43 @@ export class MySQLClient extends AntaresCore {
|
|||||||
.orderBy({ ORDINAL_POSITION: 'ASC' })
|
.orderBy({ ORDINAL_POSITION: 'ASC' })
|
||||||
.run();
|
.run();
|
||||||
|
|
||||||
// const { rows } = await this.raw(`SHOW CREATE TABLE ${schema}.${table}`);
|
const { rows: fields } = await this.raw(`SHOW CREATE TABLE ${schema}.${table}`);
|
||||||
|
|
||||||
// const fields = rows.map(row => {
|
const remappedFields = fields.map(row => {
|
||||||
// let n = 0;
|
let n = 0;
|
||||||
// return row['Create Table']
|
return row['Create Table']
|
||||||
// .split('')
|
.split('')
|
||||||
// .reduce((acc, curr) => {
|
.reduce((acc, curr) => {
|
||||||
// if (curr === ')') n--;
|
if (curr === ')') n--;
|
||||||
// if (n !== 0) acc += curr;
|
if (n !== 0) acc += curr;
|
||||||
// if (curr === '(') n++;
|
if (curr === '(') n++;
|
||||||
// return acc;
|
return acc;
|
||||||
// }, '')
|
}, '')
|
||||||
// .replaceAll('\n', '')
|
.replaceAll('\n', '')
|
||||||
// .split(',')
|
.split(',')
|
||||||
// .map(f => {
|
.map(f => {
|
||||||
// return f.trim();// TODO: here map the field
|
const fieldArr = f.trim().split(' ');
|
||||||
// });
|
const nameAndType = fieldArr.slice(0, 2);
|
||||||
// });
|
|
||||||
|
if (!nameAndType[0].includes('`')) return false;
|
||||||
|
|
||||||
|
const details = fieldArr.slice(2).join(' ');
|
||||||
|
const defaultValue = details.includes('DEFAULT') ? details.match(/(?<=DEFAULT ).*?$/gs)[0] : null;
|
||||||
|
const typeAndLength = nameAndType[1].replace(')', '').split('(');
|
||||||
|
|
||||||
|
return {
|
||||||
|
name: nameAndType[0].replaceAll('`', ''),
|
||||||
|
type: typeAndLength[0].toUpperCase(),
|
||||||
|
length: typeAndLength[1] ? typeAndLength[1] : null,
|
||||||
|
default: defaultValue
|
||||||
|
};
|
||||||
|
})
|
||||||
|
.filter(Boolean)
|
||||||
|
.reduce((acc, curr) => {
|
||||||
|
acc[curr.name] = curr;
|
||||||
|
return acc;
|
||||||
|
}, {});
|
||||||
|
})[0];
|
||||||
|
|
||||||
return rows.map(field => {
|
return rows.map(field => {
|
||||||
let numLength = field.COLUMN_TYPE.match(/int\(([^)]+)\)/);
|
let numLength = field.COLUMN_TYPE.match(/int\(([^)]+)\)/);
|
||||||
@@ -338,7 +357,7 @@ export class MySQLClient extends AntaresCore {
|
|||||||
return {
|
return {
|
||||||
name: field.COLUMN_NAME,
|
name: field.COLUMN_NAME,
|
||||||
key: field.COLUMN_KEY.toLowerCase(),
|
key: field.COLUMN_KEY.toLowerCase(),
|
||||||
type: field.DATA_TYPE.toUpperCase(),
|
type: remappedFields[field.COLUMN_NAME].type,
|
||||||
schema: field.TABLE_SCHEMA,
|
schema: field.TABLE_SCHEMA,
|
||||||
table: field.TABLE_NAME,
|
table: field.TABLE_NAME,
|
||||||
numPrecision: field.NUMERIC_PRECISION,
|
numPrecision: field.NUMERIC_PRECISION,
|
||||||
@@ -350,7 +369,7 @@ export class MySQLClient extends AntaresCore {
|
|||||||
unsigned: field.COLUMN_TYPE.includes('unsigned'),
|
unsigned: field.COLUMN_TYPE.includes('unsigned'),
|
||||||
zerofill: field.COLUMN_TYPE.includes('zerofill'),
|
zerofill: field.COLUMN_TYPE.includes('zerofill'),
|
||||||
order: field.ORDINAL_POSITION,
|
order: field.ORDINAL_POSITION,
|
||||||
default: field.COLUMN_DEFAULT, // TODO: get from show create table
|
default: remappedFields[field.COLUMN_NAME].default,
|
||||||
charset: field.CHARACTER_SET_NAME,
|
charset: field.CHARACTER_SET_NAME,
|
||||||
collation: field.COLLATION_NAME,
|
collation: field.COLLATION_NAME,
|
||||||
autoIncrement: field.EXTRA.includes('auto_increment'),
|
autoIncrement: field.EXTRA.includes('auto_increment'),
|
||||||
|
@@ -250,10 +250,15 @@ export default {
|
|||||||
if (field.default === 'NULL') fieldDefault = null;
|
if (field.default === 'NULL') fieldDefault = null;
|
||||||
else {
|
else {
|
||||||
if ([...NUMBER, ...FLOAT].includes(field.type))
|
if ([...NUMBER, ...FLOAT].includes(field.type))
|
||||||
fieldDefault = +field.default;
|
fieldDefault = Number.isNaN(+field.default) ? null : +field.default;
|
||||||
|
|
||||||
if ([...TEXT, ...LONG_TEXT].includes(field.type))
|
if ([...TEXT, ...LONG_TEXT].includes(field.type)) {
|
||||||
fieldDefault = field.default;
|
fieldDefault = field.default
|
||||||
|
? field.default.includes('\'')
|
||||||
|
? field.default.split('\'')[1]
|
||||||
|
: field.default
|
||||||
|
: '';
|
||||||
|
}
|
||||||
|
|
||||||
if ([...TIME, ...DATE].includes(field.type))
|
if ([...TIME, ...DATE].includes(field.type))
|
||||||
fieldDefault = field.default;
|
fieldDefault = field.default;
|
||||||
|
@@ -450,8 +450,13 @@ export default {
|
|||||||
|
|
||||||
this.defaultValue.onUpdate = this.localRow.onUpdate;
|
this.defaultValue.onUpdate = this.localRow.onUpdate;
|
||||||
this.defaultValue.type = this.localRow.defaultType;
|
this.defaultValue.type = this.localRow.defaultType;
|
||||||
if (this.defaultValue.type === 'custom')
|
if (this.defaultValue.type === 'custom') {
|
||||||
this.defaultValue.custom = this.localRow.default;
|
this.defaultValue.custom = this.localRow.default
|
||||||
|
? this.localRow.default.includes('\'')
|
||||||
|
? this.localRow.default.split('\'')[1]
|
||||||
|
: this.localRow.default
|
||||||
|
: '';
|
||||||
|
}
|
||||||
if (this.defaultValue.type === 'expression')
|
if (this.defaultValue.type === 'expression')
|
||||||
this.defaultValue.expression = this.localRow.default;
|
this.defaultValue.expression = this.localRow.default;
|
||||||
},
|
},
|
||||||
@@ -530,7 +535,7 @@ export default {
|
|||||||
break;
|
break;
|
||||||
case 'custom':
|
case 'custom':
|
||||||
this.localRow.autoIncrement = false;
|
this.localRow.autoIncrement = false;
|
||||||
this.localRow.default = this.defaultValue.custom;
|
this.localRow.default = Number.isNaN(+this.defaultValue.custom) ? `'${this.defaultValue.custom}'` : this.defaultValue.custom;
|
||||||
break;
|
break;
|
||||||
case 'expression':
|
case 'expression':
|
||||||
this.localRow.autoIncrement = false;
|
this.localRow.autoIncrement = false;
|
||||||
|
Reference in New Issue
Block a user