Class MysqlSchemaDialect
Schema generation/reflection features for MySQL
Property Summary
-
$_driver protected
Cake\Database\Driver
The driver instance being used.
Method Summary
-
__construct() public
Constructor
-
_applyTypeSpecificColumnConversion() protected
Tries to use a matching database type to convert a SQL column definition to an abstract type definition.
-
_convertColumn() protected
Convert a MySQL column type into an abstract type.
-
_convertConstraintColumns() protected
Convert foreign key constraints references to a valid stringified list
-
_convertOnClause() protected
Convert string on clauses to the abstract ones.
-
_foreignOnClause() protected
Generate an ON clause for a foreign key.
-
_getTypeSpecificColumnSql() protected
Tries to use a matching database type to generate the SQL fragment for a single column in a table.
-
_keySql() protected
Helper method for generating key SQL snippets.
-
addConstraintSql() public
Generate the SQL queries needed to add foreign key constraints to the table
-
columnDefinitionSql() public
Create a SQL snippet for a column based on the array shape that
describeColumns()
creates. -
columnSql() public
Generate the SQL fragment for a single column in a table.
-
constraintSql() public
Generate the SQL fragments for defining table constraints.
-
convertColumnDescription() public
Convert field description results into abstract schema fields.
-
convertForeignKeyDescription() public
Convert a foreign key description into constraints on the Table object.
-
convertIndexDescription() public
Convert an index description results into abstract schema indexes or constraints.
-
convertOptionsDescription() public
Convert options data into table options.
-
createTableSql() public
Generate the SQL to create a table.
-
describe() public
Get the column metadata for a table.
-
describeColumnSql() public
Generate the SQL to describe a table.
-
describeColumns() public
Get a list of column metadata as a array
-
describeForeignKeySql() public
Generate the SQL to describe the foreign keys in a table.
-
describeForeignKeys() public
Get a list of constraint metadata as a array
-
describeIndexSql() public
Generate the SQL to describe the indexes in a table.
-
describeIndexes() public
Get a list of index metadata as a array
-
describeOptions() public
Get platform specific options
-
describeOptionsSql() public
Generate the SQL to describe table options
-
dropConstraintSql() public
Generate the SQL queries needed to drop foreign key constraints from the table
-
dropTableSql() public
Generate the SQL to drop a table.
-
hasColumn() public
Check if a table has a column with a given name.
-
hasForeignKey() public
Check if a table has a foreign key with a given name.
-
hasIndex() public
Check if a table has an index with a given name.
-
hasTable() public
Check if a table exists
-
indexSql() public
Generate the SQL fragment for a single index in a table.
-
listTables() public
Get the list of tables and views available in the current connection.
-
listTablesSql() public
Generate the SQL to list the tables and views.
-
listTablesWithoutViews() public
Get the list of tables, excluding any views, available in the current connection.
-
listTablesWithoutViewsSql() public
Generate the SQL to list the tables, excluding all views.
-
truncateTableSql() public
Generate the SQL to truncate a table.
Method Detail
__construct() ¶ public
__construct(Cake\Database\Driver $driver)
Constructor
This constructor will connect the driver so that methods like columnSql() and others will fail when the driver has not been connected.
Parameters
-
Cake\Database\Driver
$driver The driver to use.
_applyTypeSpecificColumnConversion() ¶ protected
_applyTypeSpecificColumnConversion(string $columnType, array $definition): array|null
Tries to use a matching database type to convert a SQL column definition to an abstract type definition.
Parameters
-
string
$columnType The column type.
-
array
$definition The column definition.
Returns
array|null
_convertColumn() ¶ protected
_convertColumn(string $column): array<string, mixed>
Convert a MySQL column type into an abstract type.
The returned type will be a type that Cake\Database\TypeFactory can handle.
Parameters
-
string
$column The column type + length
Returns
array<string, mixed>
Throws
Cake\Database\Exception\DatabaseException
When column type cannot be parsed.
_convertConstraintColumns() ¶ protected
_convertConstraintColumns(array<string>|string $references): string
Convert foreign key constraints references to a valid stringified list
Parameters
-
array<string>|string
$references The referenced columns of a foreign key constraint statement
Returns
string
_convertOnClause() ¶ protected
_convertOnClause(string $clause): string
Convert string on clauses to the abstract ones.
Parameters
-
string
$clause The on clause to convert.
Returns
string
_foreignOnClause() ¶ protected
_foreignOnClause(string $on): string
Generate an ON clause for a foreign key.
Parameters
-
string
$on The on clause
Returns
string
_getTypeSpecificColumnSql() ¶ protected
_getTypeSpecificColumnSql(string $columnType, Cake\Database\Schema\TableSchemaInterface $schema, string $column): string|null
Tries to use a matching database type to generate the SQL fragment for a single column in a table.
Parameters
-
string
$columnType The column type.
-
Cake\Database\Schema\TableSchemaInterface
$schema The table schema instance the column is in.
-
string
$column The name of the column.
Returns
string|null
_keySql() ¶ protected
_keySql(string $prefix, array $data): string
Helper method for generating key SQL snippets.
Parameters
-
string
$prefix The key prefix
-
array
$data Key data.
Returns
string
addConstraintSql() ¶ public
addConstraintSql(Cake\Database\Schema\TableSchema $schema): array
Generate the SQL queries needed to add foreign key constraints to the table
Parameters
-
Cake\Database\Schema\TableSchema
$schema
Returns
array
columnDefinitionSql() ¶ public
columnDefinitionSql(array $column): string
Create a SQL snippet for a column based on the array shape
that describeColumns()
creates.
Parameters
-
array
$column The column metadata
Returns
string
columnSql() ¶ public
columnSql(Cake\Database\Schema\TableSchema $schema, string $name): string
Generate the SQL fragment for a single column in a table.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
string
$name
Returns
string
constraintSql() ¶ public
constraintSql(Cake\Database\Schema\TableSchema $schema, string $name): string
Generate the SQL fragments for defining table constraints.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
string
$name
Returns
string
convertColumnDescription() ¶ public
convertColumnDescription(Cake\Database\Schema\TableSchema $schema, array $row): void
Convert field description results into abstract schema fields.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
array
$row
Returns
void
convertForeignKeyDescription() ¶ public
convertForeignKeyDescription(Cake\Database\Schema\TableSchema $schema, array $row): void
Convert a foreign key description into constraints on the Table object.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
array
$row
Returns
void
convertIndexDescription() ¶ public
convertIndexDescription(Cake\Database\Schema\TableSchema $schema, array $row): void
Convert an index description results into abstract schema indexes or constraints.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
array
$row
Returns
void
convertOptionsDescription() ¶ public
convertOptionsDescription(Cake\Database\Schema\TableSchema $schema, array $row): void
Convert options data into table options.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
array
$row
Returns
void
createTableSql() ¶ public
createTableSql(Cake\Database\Schema\TableSchema $schema, array<string> $columns, array<string> $constraints, array<string> $indexes): array<string>
Generate the SQL to create a table.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
array<string>
$columns -
array<string>
$constraints -
array<string>
$indexes
Returns
array<string>
describe() ¶ public
describe(string $name): Cake\Database\Schema\TableSchemaInterface
Get the column metadata for a table.
The name can include a database schema name in the form 'schema.table'.
Parameters
-
string
$name The name of the table to describe.
Returns
Cake\Database\Schema\TableSchemaInterface
Throws
Cake\Database\Exception\DatabaseException
when table cannot be described.
describeColumnSql() ¶ public
describeColumnSql(string $tableName, array<string, mixed> $config): array
Generate the SQL to describe a table.
Parameters
-
string
$tableName -
array<string, mixed>
$config
Returns
array
describeColumns() ¶ public
describeColumns(string $tableName): array
Get a list of column metadata as a array
Each item in the array will contain the following:
- name : the name of the column.
- type : the abstract type of the column.
- length : the length of the column.
- default : the default value of the column or null.
- null : boolean indicating whether the column can be null.
- comment : the column comment or null.
The following keys will be set as required:
- autoIncrement : set for columns that are an integer primary key.
- onUpdate : set for datetime/timestamp columns with
ON UPDATE
clauses.
Parameters
-
string
$tableName The name of the table to describe columns on.
Returns
array
describeForeignKeySql() ¶ public
describeForeignKeySql(string $tableName, array<string, mixed> $config): array
Generate the SQL to describe the foreign keys in a table.
Parameters
-
string
$tableName -
array<string, mixed>
$config
Returns
array
describeForeignKeys() ¶ public
describeForeignKeys(string $tableName): array
Get a list of constraint metadata as a array
Each item in the array will contain the following:
- name : The name of the constraint
- type : the type of the constraint. Generally
foreign
. - columns : the columns in the constraint on the.
- references : A list of the table + all columns in the referenced table
- update : The update action or null
- delete : The delete action or null
Parameters
-
string
$tableName
Returns
array
describeIndexSql() ¶ public
describeIndexSql(string $tableName, array<string, mixed> $config): array
Generate the SQL to describe the indexes in a table.
Parameters
-
string
$tableName -
array<string, mixed>
$config
Returns
array
describeIndexes() ¶ public
describeIndexes(string $tableName): array
Get a list of index metadata as a array
Each item in the array will contain the following:
- name : the name of the index.
- type : the type of the index. One of
unique
,index
,primary
. - columns : the columns in the index.
- length : the length of the index if applicable.
Parameters
-
string
$tableName
Returns
array
describeOptions() ¶ public
describeOptions(string $tableName): array
Get platform specific options
No keys are guaranteed to be present as they are database driver dependent.
Parameters
-
string
$tableName
Returns
array
describeOptionsSql() ¶ public
describeOptionsSql(string $tableName, array<string, mixed> $config): array
Generate the SQL to describe table options
Parameters
-
string
$tableName -
array<string, mixed>
$config
Returns
array
dropConstraintSql() ¶ public
dropConstraintSql(Cake\Database\Schema\TableSchema $schema): array
Generate the SQL queries needed to drop foreign key constraints from the table
Parameters
-
Cake\Database\Schema\TableSchema
$schema
Returns
array
dropTableSql() ¶ public
dropTableSql(Cake\Database\Schema\TableSchema $schema): array
Generate the SQL to drop a table.
Parameters
-
Cake\Database\Schema\TableSchema
$schema Schema instance
Returns
array
hasColumn() ¶ public
hasColumn(string $tableName, string $columnName): bool
Check if a table has a column with a given name.
Parameters
-
string
$tableName The name of the table
-
string
$columnName The name of the column
Returns
bool
hasForeignKey() ¶ public
hasForeignKey(string $tableName, array<string> $columns = [], string $name = null): bool
Check if a table has a foreign key with a given name.
Parameters
-
string
$tableName The name of the table
-
array<string>
$columns optional The columns in the foriegn key. Specific ordering matters.
-
string
$name optional The name of the foreign key to match on. Can be used alone, or with $columns to match keys more precisely.
Returns
bool
hasIndex() ¶ public
hasIndex(string $tableName, array<string> $columns = [], string $name = null): bool
Check if a table has an index with a given name.
Parameters
-
string
$tableName The name of the table
-
array<string>
$columns optional The columns in the index. Specific ordering matters.
-
string
$name optional The name of the index to match on. Can be used alone, or with $columns to match indexes more precisely.
Returns
bool
hasTable() ¶ public
hasTable(string $tableName): bool
Check if a table exists
Parameters
-
string
$tableName The name of the table
Returns
bool
indexSql() ¶ public
indexSql(Cake\Database\Schema\TableSchema $schema, string $name): string
Generate the SQL fragment for a single index in a table.
Parameters
-
Cake\Database\Schema\TableSchema
$schema -
string
$name
Returns
string
listTables() ¶ public
listTables(): array<string>
Get the list of tables and views available in the current connection.
Returns
array<string>
listTablesSql() ¶ public
listTablesSql(array<string, mixed> $config): array<mixed>
Generate the SQL to list the tables and views.
Parameters
-
array<string, mixed>
$config The connection configuration to use for getting tables from.
Returns
array<mixed>
listTablesWithoutViews() ¶ public
listTablesWithoutViews(): array<string>
Get the list of tables, excluding any views, available in the current connection.
Returns
array<string>
listTablesWithoutViewsSql() ¶ public
listTablesWithoutViewsSql(array<string, mixed> $config): array<mixed>
Generate the SQL to list the tables, excluding all views.
Parameters
-
array<string, mixed>
$config The connection configuration to use for getting tables from.
Returns
array<mixed>
truncateTableSql() ¶ public
truncateTableSql(Cake\Database\Schema\TableSchema $schema): array
Generate the SQL to truncate a table.
Parameters
-
Cake\Database\Schema\TableSchema
$schema
Returns
array