Class MysqlSchemaDialect
Schema generation/reflection features for MySQL
Property Summary
- 
        $_driver protectedCake\Database\DriverThe driver instance being used. 
Method Summary
- 
          __construct() publicConstructor 
- 
          _applyTypeSpecificColumnConversion() protectedTries to use a matching database type to convert a SQL column definition to an abstract type definition. 
- 
          _convertColumn() protectedConvert a MySQL column type into an abstract type. 
- 
          _convertConstraintColumns() protectedConvert foreign key constraints references to a valid stringified list 
- 
          _convertOnClause() protectedConvert string on clauses to the abstract ones. 
- 
          _foreignOnClause() protectedGenerate an ON clause for a foreign key. 
- 
          _getTypeSpecificColumnSql() protectedTries to use a matching database type to generate the SQL fragment for a single column in a table. 
- 
          _keySql() protectedHelper method for generating key SQL snippets. 
- 
          addConstraintSql() publicGenerate the SQL queries needed to add foreign key constraints to the table 
- 
          columnSql() publicGenerate the SQL fragment for a single column in a table. 
- 
          constraintSql() publicGenerate the SQL fragments for defining table constraints. 
- 
          convertColumnDescription() publicConvert field description results into abstract schema fields. 
- 
          convertForeignKeyDescription() publicConvert a foreign key description into constraints on the Table object. 
- 
          convertIndexDescription() publicConvert an index description results into abstract schema indexes or constraints. 
- 
          convertOptionsDescription() publicConvert options data into table options. 
- 
          createTableSql() publicGenerate the SQL to create a table. 
- 
          describeColumnSql() publicGenerate the SQL to describe a table. 
- 
          describeForeignKeySql() publicGenerate the SQL to describe the foreign keys in a table. 
- 
          describeIndexSql() publicGenerate the SQL to describe the indexes in a table. 
- 
          describeOptionsSql() publicGenerate the SQL to describe table options 
- 
          dropConstraintSql() publicGenerate the SQL queries needed to drop foreign key constraints from the table 
- 
          dropTableSql() publicGenerate the SQL to drop a table. 
- 
          indexSql() publicGenerate the SQL fragment for a single index in a table. 
- 
          listTablesSql() publicGenerate the SQL to list the tables and views. 
- 
          listTablesWithoutViewsSql() publicGenerate the SQL to list the tables, excluding all views. 
- 
          truncateTableSql() publicGenerate 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|nullTries 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\DatabaseExceptionWhen column type cannot be parsed.
_convertConstraintColumns() ¶ protected
_convertConstraintColumns(array<string>|string $references): stringConvert 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): stringConvert string on clauses to the abstract ones.
Parameters
- 
                string$clause
- The on clause to convert. 
Returns
string_foreignOnClause() ¶ protected
_foreignOnClause(string $on): stringGenerate 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|nullTries 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): stringHelper method for generating key SQL snippets.
Parameters
- 
                string$prefix
- The key prefix 
- 
                array$data
- Key data. 
Returns
stringaddConstraintSql() ¶ public
addConstraintSql(Cake\Database\Schema\TableSchema $schema): arrayGenerate the SQL queries needed to add foreign key constraints to the table
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
Returns
arraycolumnSql() ¶ public
columnSql(Cake\Database\Schema\TableSchema $schema, string $name): stringGenerate the SQL fragment for a single column in a table.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                string$name
Returns
stringconstraintSql() ¶ public
constraintSql(Cake\Database\Schema\TableSchema $schema, string $name): stringGenerate the SQL fragments for defining table constraints.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                string$name
Returns
stringconvertColumnDescription() ¶ public
convertColumnDescription(Cake\Database\Schema\TableSchema $schema, array $row): voidConvert field description results into abstract schema fields.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                array$row
Returns
voidconvertForeignKeyDescription() ¶ public
convertForeignKeyDescription(Cake\Database\Schema\TableSchema $schema, array $row): voidConvert a foreign key description into constraints on the Table object.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                array$row
Returns
voidconvertIndexDescription() ¶ public
convertIndexDescription(Cake\Database\Schema\TableSchema $schema, array $row): voidConvert an index description results into abstract schema indexes or constraints.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                array$row
Returns
voidconvertOptionsDescription() ¶ public
convertOptionsDescription(Cake\Database\Schema\TableSchema $schema, array $row): voidConvert options data into table options.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                array$row
Returns
voidcreateTableSql() ¶ 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>describeColumnSql() ¶ public
describeColumnSql(string $tableName, array<string, mixed> $config): arrayGenerate the SQL to describe a table.
Parameters
- 
                string$tableName
- 
                array<string, mixed>$config
Returns
arraydescribeForeignKeySql() ¶ public
describeForeignKeySql(string $tableName, array<string, mixed> $config): arrayGenerate the SQL to describe the foreign keys in a table.
Parameters
- 
                string$tableName
- 
                array<string, mixed>$config
Returns
arraydescribeIndexSql() ¶ public
describeIndexSql(string $tableName, array<string, mixed> $config): arrayGenerate the SQL to describe the indexes in a table.
Parameters
- 
                string$tableName
- 
                array<string, mixed>$config
Returns
arraydescribeOptionsSql() ¶ public
describeOptionsSql(string $tableName, array<string, mixed> $config): arrayGenerate the SQL to describe table options
Parameters
- 
                string$tableName
- 
                array<string, mixed>$config
Returns
arraydropConstraintSql() ¶ public
dropConstraintSql(Cake\Database\Schema\TableSchema $schema): arrayGenerate the SQL queries needed to drop foreign key constraints from the table
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
Returns
arraydropTableSql() ¶ public
dropTableSql(Cake\Database\Schema\TableSchema $schema): arrayGenerate the SQL to drop a table.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- Schema instance 
Returns
arrayindexSql() ¶ public
indexSql(Cake\Database\Schema\TableSchema $schema, string $name): stringGenerate the SQL fragment for a single index in a table.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
- 
                string$name
Returns
stringlistTablesSql() ¶ 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>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): arrayGenerate the SQL to truncate a table.
Parameters
- 
                Cake\Database\Schema\TableSchema$schema
Returns
array