本文整理匯總了PHP中yii\db\Migration::addColumn方法的典型用法代碼示例。如果您正苦於以下問題:PHP Migration::addColumn方法的具體用法?PHP Migration::addColumn怎麽用?PHP Migration::addColumn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類yii\db\Migration
的用法示例。
在下文中一共展示了Migration::addColumn方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: addColumn
/**
* @inheritdoc
* Note: table will be auto pefixied if [[$autoWrapTableNames]] is true.
*/
public function addColumn($table, $column, $type)
{
$table = $this->autoWrappedTableName($table);
return parent::addColumn($table, $column, $type);
}
示例2: addColumn
/**
* @inheritdoc
*/
public function addColumn($table, $column, $type)
{
parent::addColumn($table, $column, $this->fixColumnType($type));
}
示例3: afterSave
/**
* @param bool $insert
* @param array $changedAttributes
* @return bool
*/
public function afterSave($insert, $changedAttributes)
{
parent::afterSave($insert, $changedAttributes);
if (!in_array($this->scenario, ['update', 'create'])) {
return true;
}
$cm = $this->cm;
$mg = new Migration();
$table = Cm::$TAB_PREFIX[$cm->tab_index] . $cm->tab;
$column = null;
$type = $this->data_type;
switch ($type) {
case 'integer':
case 'smallInteger':
case 'boolean':
case 'float':
case 'double':
$column = $mg->{$type}()->notNull()->defaultValue(0);
break;
case 'string':
$column = $mg->{$type}($this->length)->notNull()->defaultValue('');
break;
case 'decimal':
$column = $mg->{$type}($this->length)->notNull()->defaultValue(0);
break;
default:
$column = $mg->{$type}()->defaultValue(null);
break;
}
$column .= " COMMENT '" . $this->label . "'";
if ($insert) {
$mg->addColumn('{{%' . $table . '}}', $this->name, $column);
} else {
$oldName = $this->old_name;
$newname = $this->name;
if ($oldName !== $newname) {
$mg->renameColumn('{{%' . $table . '}}', $oldName, $newname);
}
$mg->alterColumn('{{%' . $table . '}}', $newname, $column);
}
return true;
}
示例4: addColumn
public function addColumn($tableName, $column, $type)
{
$table = Yii::$app->db->schema->getTableSchema($tableName);
if (!isset($table->columns[$column])) {
parent::addColumn($tableName, $column, $type);
}
}
示例5: addColumn
public function addColumn($table, $column, $type)
{
if ($type instanceof ForeignKeyColumn) {
parent::addColumn($table, $column, $this->integer());
$type->migrate = $this;
$type->sourceTable($table);
$type->sourceColumn($column);
$type->apply();
} else {
return parent::addColumn($table, $column, $type);
}
}
示例6: addColumns
/**
* Add multiple columns to a table
* @param string $table
* @param array $columns ["column_name"=>type]
*/
public function addColumns($table, $columns)
{
foreach ($columns as $column => $type) {
parent::addColumn($table, $column, $type);
}
}