From 2ba9de3bc69295d3663fdf0494d81134d6c220fd Mon Sep 17 00:00:00 2001 From: Adamo Tonete <5470767+adamotonete@users.noreply.github.com> Date: Fri, 1 Oct 2021 13:37:26 -0300 Subject: [PATCH] Added support for additional field Clustered on TiDB Added field Clustered, which is a particular field on show indexes in TiDB. --- tableparser/tableparser.go | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/tableparser/tableparser.go b/tableparser/tableparser.go index f04e383..53f371c 100644 --- a/tableparser/tableparser.go +++ b/tableparser/tableparser.go @@ -70,6 +70,7 @@ type IndexField struct { NonUnique bool Visible string // MySQL 8.0+ Expression sql.NullString // MySQL 8.0.16+ + Clustered string // TiDB Support } // Constraint holds Foreign Keys information @@ -136,7 +137,9 @@ func New(db *sql.DB, schema, tableName string) (*Table, error) { if err != nil { return nil, err } + table.Constraints, err = getConstraints(db, table.Schema, table.Name) + if err != nil { return nil, err } @@ -295,6 +298,10 @@ func getIndexes(db *sql.DB, schema, tableName string) (map[string]Index, error) if err == nil && len(cols) >= 15 && cols[14] == "Expression" { fields = append(fields, &i.Expression) } + // support for TiDB (Clustered Index) + if err == nil && len(cols) >= 16 && cols[15] == "Clustered" { + fields = append(fields, &i.Clustered) + } err = rows.Scan(fields...) if err != nil {