1
0
mirror of https://github.com/ManyakRus/crud_generator.git synced 2025-01-03 01:22:21 +02:00
crud_generator/pkg/dbmeta/meta_unknown.go

91 lines
2.0 KiB
Go
Raw Normal View History

2023-10-24 17:03:04 +02:00
package dbmeta
import (
"database/sql"
"fmt"
"regexp"
"strconv"
"strings"
"github.com/jimsmart/schema"
)
// LoadUnknownMeta fetch db meta data for unknown database type
func LoadUnknownMeta(db *sql.DB, sqlType, sqlDatabase, tableName string) (DbTableMeta, error) {
m := &dbTableMeta{
sqlType: sqlType,
sqlDatabase: sqlDatabase,
tableName: tableName,
}
cols, err := schema.ColumnTypes(db, sqlDatabase, tableName)
if err != nil {
return nil, err
}
m.columns = make([]*columnMeta, len(cols))
infoSchema, err := LoadTableInfoFromMSSqlInformationSchema(db, tableName)
if err != nil {
fmt.Printf("NOTICE unable to load InformationSchema table: %s error: %v\n", tableName, err)
}
for i, v := range cols {
nullable, ok := v.Nullable()
if !ok {
nullable = false
}
isAutoIncrement := false
isPrimaryKey := i == 0
colDDL := v.DatabaseTypeName()
defaultVal := ""
columnType, columnLen := ParseSQLType(v.DatabaseTypeName())
if columnLen == -1 {
dbType := strings.ToLower(v.DatabaseTypeName())
if strings.Contains(dbType, "varchar") {
re := regexp.MustCompile(`[-]?\d[\d,]*[\.]?[\d{2}]*`)
submatchall := re.FindAllString(dbType, -1)
if len(submatchall) > 0 {
i, err := strconv.Atoi(submatchall[0])
if err == nil {
columnLen = int64(i)
}
}
}
}
if infoSchema != nil {
infoSchemaColInfo, ok := infoSchema[v.Name()]
if ok {
if infoSchemaColInfo.ColumnDefault != nil {
defaultVal = BytesToString(infoSchemaColInfo.ColumnDefault.([]uint8))
defaultVal = cleanupDefault(defaultVal)
}
}
}
colMeta := &columnMeta{
index: i,
name: v.Name(),
databaseTypeName: columnType,
nullable: nullable,
isPrimaryKey: isPrimaryKey,
isAutoIncrement: isAutoIncrement,
colDDL: colDDL,
defaultVal: defaultVal,
columnType: columnType,
columnLen: columnLen,
}
m.columns[i] = colMeta
}
m.ddl = BuildDefaultTableDDL(tableName, m.columns)
m = updateDefaultPrimaryKey(m)
return m, nil
}