本文整理匯總了PHP中yii\db\Migration::createIndex方法的典型用法代碼示例。如果您正苦於以下問題:PHP Migration::createIndex方法的具體用法?PHP Migration::createIndex怎麽用?PHP Migration::createIndex使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類yii\db\Migration
的用法示例。
在下文中一共展示了Migration::createIndex方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: createIndex
public function createIndex($name, $table, $columns, $unique = false)
{
if (is_null($name)) {
$name = self::formIndexName($table, $columns, $unique ? "unq" : "idx");
}
return parent::createIndex($name, $table, $columns, $unique);
}
示例2: createIndex
/**
* Builds and executes a SQL statement for creating a new index.
* @param string $name the name of the index. The name will be properly quoted by the method.
* @param string $table the table that the new index will be created for. The table name will be properly quoted by the method.
* @param string $column the column(s) that should be included in the index. If there are multiple columns, please separate them
* by commas or use an array. The column names will be properly quoted by the method.
* @param boolean $unique whether to add UNIQUE constraint on the created index.
*/
public function createIndex($name, $table, $column, $unique = false)
{
if (in_array($this->db->getDriverName(), array('mysql', 'mysqli')) && $table != strtolower($table)) {
echo " > create (via alter table)" . ($unique ? ' unique' : '') . " index {$name} on {$table} (" . implode(',', (array) $column) . ") ...";
$time = microtime(true);
$sql = 'ALTER TABLE ' . $this->db->quoteTableName($table) . ' ADD ' . ($unique ? 'UNIQUE INDEX' : 'INDEX') . ' ' . $this->db->quoteTableName($name) . ' (' . $this->db->getQueryBuilder()->buildColumns($column) . ')';
$this->db->createCommand($sql)->execute();
echo " done (time: " . sprintf('%.3f', microtime(true) - $time) . "s)\n";
} else {
parent::createIndex($name, $table, $column, $unique);
}
}
示例3: createIndex
/**
* @inheritdoc
* Note: table will be auto pefixied if [[$autoWrapTableNames]] is true.
*/
public function createIndex($name, $table, $columns, $unique = false)
{
$table = $this->autoWrappedTableName($table);
return parent::createIndex($name, $table, $columns, $unique);
}
示例4: createIndex
/**
* @inheritdoc
* @param string|null $name
*/
public function createIndex($name, $table, $columns, $unique = false)
{
if (is_null($name)) {
$name = implode('-', (array) $columns);
}
parent::createIndex($name, $table, $columns, $unique);
}
示例5: createIndex
/**
* Builds and executes a SQL statement for creating a new index.
* @param string $name the name of the index. The name will be properly quoted by the method.
* @param string $table the table that the new index will be created for. The table name will be properly quoted by the method.
* @param string|array $columns the column(s) that should be included in the index. If there are multiple columns, please separate them
* by commas or use an array. Each column name will be properly quoted by the method. Quoting will be skipped for column names that
* include a left parenthesis "(".
* @param boolean $unique whether to add UNIQUE constraint on the created index.
*/
public function createIndex($table, $columns, $unique = false, $name = null)
{
$name = $name ?: $this->getNameIndex($table, $columns);
parent::createIndex($name, $table, $columns, $unique);
}