Skip to content

Commit

Permalink
Merge pull request #30 from dutow/8016fix
Browse files Browse the repository at this point in the history
Handle 8.0.16 expression indexes. Fixes #27.
  • Loading branch information
percona-csalguero authored Jul 22, 2019
2 parents ec5066c + 88d4bd1 commit 9e592f7
Showing 1 changed file with 14 additions and 8 deletions.
22 changes: 14 additions & 8 deletions tableparser/tableparser.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ type Index struct {
Fields []string
Unique bool
Visible bool
Expression string // MySQL 8.0.16+
}

// IndexField holds raw index information as defined in INFORMATION_SCHEMA table
Expand All @@ -67,7 +68,8 @@ type IndexField struct {
Comment string
IndexComment string
NonUnique bool
Visible bool // MySQL 8.0+
Visible string // MySQL 8.0+
Expression sql.NullString // MySQL 8.0.16+
}

// Constraint holds Foreign Keys information
Expand Down Expand Up @@ -262,15 +264,18 @@ func getIndexes(db *sql.DB, schema, tableName string) (map[string]Index, error)

for rows.Next() {
var i IndexField
var table, visible string
var table, string
fields := []interface{}{&table, &i.NonUnique, &i.KeyName, &i.SeqInIndex,
&i.ColumnName, &i.Collation, &i.Cardinality, &i.SubPart,
&i.Packed, &i.Null, &i.IndexType, &i.Comment, &i.IndexComment,
}

cols, err := rows.Columns()
if err == nil && len(cols) == 14 && cols[13] == "Visible" {
fields = append(fields, &visible)
if err == nil && len(cols) >= 14 && cols[13] == "Visible" {
fields = append(fields, &i.Visible)
}
if err == nil && len(cols) >= 15 && cols[14] == "Expression" {
fields = append(fields, &i.Expression)
}

err = rows.Scan(fields...)
Expand All @@ -279,10 +284,11 @@ func getIndexes(db *sql.DB, schema, tableName string) (map[string]Index, error)
}
if index, ok := indexes[i.KeyName]; !ok {
indexes[i.KeyName] = Index{
Name: i.KeyName,
Unique: !i.NonUnique,
Fields: []string{i.ColumnName},
Visible: visible == "YES" || visible == "",
Name: i.KeyName,
Unique: !i.NonUnique,
Fields: []string{i.ColumnName},
Visible: i.Visible == "YES" || visible == "",
Expression: i.Expression.String,
}

} else {
Expand Down

0 comments on commit 9e592f7

Please sign in to comment.