better type habndling, shell-tableReader for preserving table structure

This commit is contained in:
Jan Prochazka
2020-06-18 21:50:37 +02:00
parent cecb88f024
commit bfc6f2a8a8
13 changed files with 52 additions and 16 deletions

View File

@@ -15,7 +15,7 @@ export function isTypeNumber(dataType) {
}
export function isTypeString(dataType) {
return dataType && /char/i.test(dataType);
return dataType && /char|binary/i.test(dataType);
}
export function isTypeLogical(dataType) {

View File

@@ -1 +1,2 @@
export * from './commonTypeParser';
export * from './nameTools';

View File

@@ -0,0 +1,47 @@
import { DatabaseInfo, DatabaseInfoObjects } from '@dbgate/types';
export function fullNameFromString(name) {
const m = name.match(/\[([^\]]+)\]\.\[([^\]]+)\]/);
if (m) {
return {
schemaName: m[1],
pureName: m[2],
};
}
return {
schemaName: null,
pureName: name,
};
}
export function fullNameToString({ schemaName, pureName }) {
if (schemaName) {
return `[${schemaName}].[${pureName}]`;
}
return pureName;
}
export function quoteFullName(dialect, { schemaName, pureName }) {
if (schemaName) return `${dialect.quoteIdentifier(schemaName)}.${dialect.quoteIdentifier(pureName)}`;
return `${dialect.quoteIdentifier(pureName)}`;
}
export function equalStringLike(s1, s2) {
return (s1 || '').toLowerCase().trim() == (s2 || '').toLowerCase().trim();
}
export function findObjectLike(
{ pureName, schemaName },
dbinfo: DatabaseInfo,
objectTypeField: keyof DatabaseInfoObjects
) {
if (!dbinfo) return null;
if (schemaName) {
// @ts-ignore
return dbinfo[objectTypeField].find(
(x) => equalStringLike(x.pureName, pureName) && equalStringLike(x.schemaName, schemaName)
);
}
// @ts-ignore
return dbinfo[objectTypeField].find((x) => equalStringLike(x.pureName, pureName));
}