package migrations import ( "fmt" "xorm.io/xorm" "xorm.io/xorm/schemas" ) func addTrustedPropsToRepo(engine *xorm.Engine) error { var err error tableName := "repository" switch engine.Dialect().URI().DBType { case schemas.POSTGRES: addColsQuery := fmt.Sprintf("ALTER TABLE \"%s\" ADD COLUMN competences TEXT, ADD COLUMN resources TEXT;", tableName) _, err = engine.Exec(addColsQuery) case schemas.SQLITE: addColsQuery := fmt.Sprintf("ALTER TABLE \"%s\" ADD COLUMN competences TEXT;\nALTER TABLE \"%s\" ADD COLUMN resources TEXT;", tableName, tableName) _, err = engine.Exec(addColsQuery) case schemas.MYSQL: addColsQuery := fmt.Sprintf("ALTER TABLE `%s` ADD COLUMN competences TEXT, ADD COLUMN resources TEXT;", tableName) _, err = engine.Exec(addColsQuery) } if err != nil { return fmt.Errorf("Ошибка добавления колонок компетенции и ресурсы в проект: %v", err) } else { return nil } }