| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- package migrations
- import . "github.com/grafana/grafana/pkg/services/sqlstore/migrator"
- func addDashboardSnapshotMigrations(mg *Migrator) {
- snapshotV4 := Table{
- Name: "dashboard_snapshot",
- Columns: []*Column{
- {Name: "id", Type: DB_BigInt, IsPrimaryKey: true, IsAutoIncrement: true},
- {Name: "name", Type: DB_NVarchar, Length: 255, Nullable: false},
- {Name: "key", Type: DB_NVarchar, Length: 190, Nullable: false},
- {Name: "dashboard", Type: DB_Text, Nullable: false},
- {Name: "expires", Type: DB_DateTime, Nullable: false},
- {Name: "created", Type: DB_DateTime, Nullable: false},
- {Name: "updated", Type: DB_DateTime, Nullable: false},
- },
- Indices: []*Index{
- {Cols: []string{"key"}, Type: UniqueIndex},
- },
- }
- // add v4
- mg.AddMigration("create dashboard_snapshot table v4", NewAddTableMigration(snapshotV4))
- mg.AddMigration("drop table dashboard_snapshot_v4 #1", NewDropTableMigration("dashboard_snapshot"))
- snapshotV5 := Table{
- Name: "dashboard_snapshot",
- Columns: []*Column{
- {Name: "id", Type: DB_BigInt, IsPrimaryKey: true, IsAutoIncrement: true},
- {Name: "name", Type: DB_NVarchar, Length: 255, Nullable: false},
- {Name: "key", Type: DB_NVarchar, Length: 190, Nullable: false},
- {Name: "delete_key", Type: DB_NVarchar, Length: 190, Nullable: false},
- {Name: "org_id", Type: DB_BigInt, Nullable: false},
- {Name: "user_id", Type: DB_BigInt, Nullable: false},
- {Name: "external", Type: DB_Bool, Nullable: false},
- {Name: "external_url", Type: DB_NVarchar, Length: 255, Nullable: false},
- {Name: "dashboard", Type: DB_Text, Nullable: false},
- {Name: "expires", Type: DB_DateTime, Nullable: false},
- {Name: "created", Type: DB_DateTime, Nullable: false},
- {Name: "updated", Type: DB_DateTime, Nullable: false},
- },
- Indices: []*Index{
- {Cols: []string{"key"}, Type: UniqueIndex},
- {Cols: []string{"delete_key"}, Type: UniqueIndex},
- {Cols: []string{"user_id"}},
- },
- }
- mg.AddMigration("create dashboard_snapshot table v5 #2", NewAddTableMigration(snapshotV5))
- addTableIndicesMigrations(mg, "v5", snapshotV5)
- // change column type of dashboard
- mg.AddMigration("alter dashboard_snapshot to mediumtext v2", new(RawSqlMigration).
- Sqlite("SELECT 0 WHERE 0;").
- Postgres("SELECT 0;").
- Mysql("ALTER TABLE dashboard_snapshot MODIFY dashboard MEDIUMTEXT;"))
- mg.AddMigration("Update dashboard_snapshot table charset", NewTableCharsetMigration("dashboard_snapshot", []*Column{
- {Name: "name", Type: DB_NVarchar, Length: 255, Nullable: false},
- {Name: "key", Type: DB_NVarchar, Length: 190, Nullable: false},
- {Name: "delete_key", Type: DB_NVarchar, Length: 190, Nullable: false},
- {Name: "external_url", Type: DB_NVarchar, Length: 255, Nullable: false},
- {Name: "dashboard", Type: DB_MediumText, Nullable: false},
- }))
- }
|