Documentation ¶
Index ¶
- Constants
- Variables
- func Build(phrase string) *sqlx.Builder
- func FormatType(t schema.Type) (string, error)
- func MarshalSpec(v interface{}, marshaler schemaspec.Marshaler) ([]byte, error)
- func ParseType(raw string) (schema.Type, error)
- func UnmarshalSpec(data []byte, unmarshaler schemaspec.Unmarshaler, v interface{}) error
- type AutoIncrement
- type BitType
- type CreateOptions
- type CreateStmt
- type DisplayWidth
- type Driver
- type Enforced
- type IndexType
- type OnUpdate
- type SetType
- type SubPart
- type ZeroFill
Constants ¶
const ( TypeBool = "bool" TypeBoolean = "boolean" TypeBit = "bit" // MYSQL_TYPE_BIT TypeInt = "int" // MYSQL_TYPE_LONG TypeTinyInt = "tinyint" // MYSQL_TYPE_TINY TypeSmallInt = "smallint" // MYSQL_TYPE_SHORT TypeMediumInt = "mediumint" // MYSQL_TYPE_INT24 TypeBigInt = "bigint" // MYSQL_TYPE_LONGLONG TypeDecimal = "decimal" // MYSQL_TYPE_DECIMAL TypeNumeric = "numeric" // MYSQL_TYPE_DECIMAL (numeric_type rule in sql_yacc.yy) TypeFloat = "float" // MYSQL_TYPE_FLOAT TypeDouble = "double" // MYSQL_TYPE_DOUBLE TypeReal = "real" // MYSQL_TYPE_FLOAT or MYSQL_TYPE_DOUBLE (real_type in sql_yacc.yy) TypeTimestamp = "timestamp" // MYSQL_TYPE_TIMESTAMP TypeDate = "date" // MYSQL_TYPE_DATE TypeTime = "time" // MYSQL_TYPE_TIME TypeDateTime = "datetime" // MYSQL_TYPE_DATETIME TypeYear = "year" // MYSQL_TYPE_YEAR TypeVarchar = "varchar" // MYSQL_TYPE_VAR_STRING, MYSQL_TYPE_VARCHAR TypeChar = "char" // MYSQL_TYPE_STRING TypeVarBinary = "varbinary" // MYSQL_TYPE_VAR_STRING + NULL CHARACTER_SET. TypeBinary = "binary" // MYSQL_TYPE_STRING + NULL CHARACTER_SET. TypeBlob = "blob" // MYSQL_TYPE_BLOB TypeTinyBlob = "tinyblob" // MYSQL_TYPE_TINYBLOB TypeMediumBlob = "mediumblob" // MYSQL_TYPE_MEDIUM_BLOB TypeLongBlob = "longblob" // MYSQL_TYPE_LONG_BLOB TypeText = "text" // MYSQL_TYPE_BLOB + CHARACTER_SET utf8mb4 TypeTinyText = "tinytext" // MYSQL_TYPE_TINYBLOB + CHARACTER_SET utf8mb4 TypeMediumText = "mediumtext" // MYSQL_TYPE_MEDIUM_BLOB + CHARACTER_SET utf8mb4 TypeLongText = "longtext" // MYSQL_TYPE_LONG_BLOB with + CHARACTER_SET utf8mb4 TypeEnum = "enum" // MYSQL_TYPE_ENUM TypeSet = "set" // MYSQL_TYPE_SET TypeJSON = "json" // MYSQL_TYPE_JSON TypeGeometry = "geometry" // MYSQL_TYPE_GEOMETRY TypePoint = "point" // Geometry_type::kPoint TypeMultiPoint = "multipoint" // Geometry_type::kMultipoint TypeLineString = "linestring" // Geometry_type::kLinestring TypeMultiLineString = "multilinestring" // Geometry_type::kMultilinestring TypePolygon = "polygon" // Geometry_type::kPolygon TypeMultiPolygon = "multipolygon" // Geometry_type::kMultipolygon TypeGeoCollection = "geomcollection" // Geometry_type::kGeometrycollection TypeGeometryCollection = "geometrycollection" // Geometry_type::kGeometrycollection )
MySQL standard column types as defined in its codebase. Name and order is organized differently than MySQL.
https://github.com/mysql/mysql-server/blob/8.0/include/field_types.h https://github.com/mysql/mysql-server/blob/8.0/sql/dd/types/column.h https://github.com/mysql/mysql-server/blob/8.0/sql/sql_show.cc https://github.com/mysql/mysql-server/blob/8.0/sql/gis/geometries.cc https://dev.mysql.com/doc/refman/8.0/en/other-vendor-data-types.html
const ( IndexTypeBTree = "BTREE" IndexTypeHash = "HASH" IndexTypeFullText = "FULLTEXT" IndexTypeSpatial = "SPATIAL" )
Additional common constants in MySQL.
Variables ¶
var ( // UnmarshalHCL unmarshals an Atlas HCL DDL document into v. UnmarshalHCL = schemaspec.UnmarshalerFunc(func(bytes []byte, i interface{}) error { return UnmarshalSpec(bytes, hclState, i) }) // MarshalHCL marshals v into an Atlas HCL DDL document. MarshalHCL = schemaspec.MarshalerFunc(func(v interface{}) ([]byte, error) { return MarshalSpec(v, hclState) }) )
var TypeRegistry = specutil.NewRegistry( specutil.WithFormatter(FormatType), specutil.WithParser(ParseType), specutil.WithSpecs( &schemaspec.TypeSpec{ Name: TypeEnum, T: TypeEnum, Attributes: []*schemaspec.TypeAttr{ {Name: "values", Kind: reflect.Slice, Required: true}, }, RType: reflect.TypeOf(schema.EnumType{}), }, &schemaspec.TypeSpec{ Name: TypeSet, T: TypeSet, Attributes: []*schemaspec.TypeAttr{ {Name: "values", Kind: reflect.Slice, Required: true}, }, RType: reflect.TypeOf(SetType{}), }, specutil.TypeSpec(TypeBool), specutil.TypeSpec(TypeBoolean), specutil.TypeSpec(TypeBit, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeInt, specutil.WithAttributes(unsignedTypeAttr(), specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeTinyInt, specutil.WithAttributes(unsignedTypeAttr(), specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeSmallInt, specutil.WithAttributes(unsignedTypeAttr(), specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeMediumInt, specutil.WithAttributes(unsignedTypeAttr(), specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeBigInt, specutil.WithAttributes(unsignedTypeAttr(), specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeDecimal, specutil.WithAttributes(unsignedTypeAttr(), &schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false}, &schemaspec.TypeAttr{Name: "scale", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeNumeric, specutil.WithAttributes(unsignedTypeAttr(), &schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false}, &schemaspec.TypeAttr{Name: "scale", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeFloat, specutil.WithAttributes(unsignedTypeAttr(), &schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false}, &schemaspec.TypeAttr{Name: "scale", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeDouble, specutil.WithAttributes(unsignedTypeAttr(), &schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false}, &schemaspec.TypeAttr{Name: "scale", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeReal, specutil.WithAttributes(unsignedTypeAttr(), &schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false}, &schemaspec.TypeAttr{Name: "scale", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeTimestamp, specutil.WithAttributes(&schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeDate, specutil.WithAttributes(&schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeTime, specutil.WithAttributes(&schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeDateTime, specutil.WithAttributes(&schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeYear, specutil.WithAttributes(&schemaspec.TypeAttr{Name: "precision", Kind: reflect.Int, Required: false})), specutil.TypeSpec(TypeVarchar, specutil.WithAttributes(specutil.SizeTypeAttr(true))), specutil.TypeSpec(TypeChar, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeVarBinary, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeBinary, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeBlob, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeTinyBlob), specutil.TypeSpec(TypeMediumBlob), specutil.TypeSpec(TypeLongBlob), specutil.TypeSpec(TypeJSON), specutil.TypeSpec(TypeText, specutil.WithAttributes(specutil.SizeTypeAttr(false))), specutil.TypeSpec(TypeTinyText), specutil.TypeSpec(TypeMediumText), specutil.TypeSpec(TypeLongText), specutil.TypeSpec(TypeGeometry), specutil.TypeSpec(TypePoint), specutil.TypeSpec(TypeMultiPoint), specutil.TypeSpec(TypeLineString), specutil.TypeSpec(TypeMultiLineString), specutil.TypeSpec(TypePolygon), specutil.TypeSpec(TypeMultiPolygon), specutil.TypeSpec(TypeGeometryCollection), ), )
TypeRegistry contains the supported TypeSpecs for the mysql driver.
Functions ¶
func FormatType ¶ added in v0.2.0
FormatType converts schema type to its column form in the database. An error is returned if the type cannot be recognized.
func MarshalSpec ¶
func MarshalSpec(v interface{}, marshaler schemaspec.Marshaler) ([]byte, error)
MarshalSpec marshals v into an Atlas DDL document using a schemaspec.Marshaler.
func ParseType ¶ added in v0.2.0
ParseType returns the schema.Type value represented by the given raw type. The raw value is expected to follow the format in MySQL information schema.
func UnmarshalSpec ¶
func UnmarshalSpec(data []byte, unmarshaler schemaspec.Unmarshaler, v interface{}) error
UnmarshalSpec unmarshals an Atlas DDL document using an unmarshaler into v.
Types ¶
type AutoIncrement ¶
AutoIncrement attribute for columns with "AUTO_INCREMENT" as a default. V represent an optional start value for the counter.
type CreateOptions ¶ added in v0.2.0
CreateOptions attribute for describing extra options used with CREATE TABLE.
type CreateStmt ¶ added in v0.3.0
CreateStmt describes the SQL statement used to create a table.
type DisplayWidth ¶
The DisplayWidth represents a display width of an integer type.
type Driver ¶
type Driver struct { schema.Differ schema.Inspector migrate.PlanApplier // contains filtered or unexported fields }
Driver represents a MySQL driver for introspecting database schemas, generating diff between schema elements and apply migrations changes.
func (*Driver) NormalizeRealm ¶ added in v0.3.6
NormalizeRealm returns the normal representation of the given database.