(stmt *ast.RenameColumnStmt)
| 390 | } |
| 391 | |
| 392 | func (c *Catalog) renameColumn(stmt *ast.RenameColumnStmt) error { |
| 393 | _, tbl, err := c.getTable(stmt.Table) |
| 394 | if err != nil { |
| 395 | return checkMissing(err, stmt.MissingOk) |
| 396 | } |
| 397 | idx := -1 |
| 398 | for i := range tbl.Columns { |
| 399 | if tbl.Columns[i].Name == stmt.Col.Name { |
| 400 | idx = i |
| 401 | } |
| 402 | if tbl.Columns[i].Name == *stmt.NewName { |
| 403 | return sqlerr.ColumnExists(tbl.Rel.Name, *stmt.NewName) |
| 404 | } |
| 405 | } |
| 406 | if idx == -1 { |
| 407 | return sqlerr.ColumnNotFound(tbl.Rel.Name, stmt.Col.Name) |
| 408 | } |
| 409 | tbl.Columns[idx].Name = *stmt.NewName |
| 410 | |
| 411 | if tbl.Columns[idx].linkedType { |
| 412 | name := fmt.Sprintf("%s_%s", tbl.Rel.Name, *stmt.NewName) |
| 413 | rename := &ast.RenameTypeStmt{ |
| 414 | Type: &tbl.Columns[idx].Type, |
| 415 | NewName: &name, |
| 416 | } |
| 417 | if err := c.renameType(rename); err != nil { |
| 418 | return err |
| 419 | } |
| 420 | } |
| 421 | |
| 422 | return nil |
| 423 | } |
| 424 | |
| 425 | func (c *Catalog) renameTable(stmt *ast.RenameTableStmt) error { |
| 426 | sch, tbl, err := c.getTable(stmt.Table) |
no test coverage detected