当前位置: 首页>>代码示例>>PHP>>正文


PHP Migration::dropForeignKey方法代码示例

本文整理汇总了PHP中yii\db\Migration::dropForeignKey方法的典型用法代码示例。如果您正苦于以下问题:PHP Migration::dropForeignKey方法的具体用法?PHP Migration::dropForeignKey怎么用?PHP Migration::dropForeignKey使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在yii\db\Migration的用法示例。


在下文中一共展示了Migration::dropForeignKey方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: actionUpdate

 /**
  * Update ip-geo-base data
  *
  * @throws \yii\base\Exception
  */
 public function actionUpdate()
 {
     $migrate = new Migration();
     $migrate->dropForeignKey('fk-geobase_contact-geobase_city_id', 'geobase_contact');
     $ipGeoBase = new IpGeoBase();
     $ipGeoBase->updateDB();
     $migrate->addForeignKey('fk-geobase_contact-geobase_city_id', 'geobase_contact', 'geobase_city_id', 'geobase_city', 'id', 'CASCADE', 'CASCADE');
 }
开发者ID:mark38,项目名称:yii2-site-mng,代码行数:13,代码来源:DefaultController.php

示例2: dropTable

 public function dropTable()
 {
     if ($this->dropOriginTable) {
         if (in_array($this->tableNameRaw, $this->_connection->schema->tableNames)) {
             $schema = $this->_connection->schema->getTableSchema($this->tableNameRaw);
             if ($schema) {
                 $keys = $schema->foreignKeys;
                 if (is_array($keys)) {
                     foreach ($keys as $name => $_next) {
                         $t = [];
                         foreach ($_next as $k => $v) {
                             if (!$k) {
                                 $t['related_table'] = $v;
                             } else {
                                 $t['related_field'] = $v;
                                 $t['field'] = $k;
                             }
                         }
                         try {
                             $keyName = $this->getNameForeignKey($this->tableNameRaw, $t['related_table'], $_next[$t['field']], $t['related_field'], 255);
                             if ($this->hideMigrationOutput) {
                                 ob_start();
                             }
                             $this->migrationClass->dropForeignKey($keyName, $this->tableNameRaw);
                             if ($this->hideMigrationOutput) {
                                 ob_clean();
                                 ob_flush();
                             }
                         } catch (\yii\db\Exception $exp) {
                         }
                     }
                 }
                 if ($this->hideMigrationOutput) {
                     ob_start();
                 }
                 try {
                     $this->migrationClass->dropTable($this->tableNameRaw);
                 } catch (\yii\db\Exception $exp) {
                 } catch (IntegrityException $exp) {
                 }
                 if ($this->hideMigrationOutput) {
                     ob_clean();
                     ob_flush();
                 }
             }
         }
     }
 }
开发者ID:infinitydevphp,项目名称:yii2-table-builder,代码行数:48,代码来源:TableBuilder.php

示例3: dropForeignKey

 /**
  * @inheritdoc
  * Note: table will be auto pefixied if [[$autoWrapTableNames]] is true.
  */
 public function dropForeignKey($name, $table)
 {
     $table = $this->autoWrappedTableName($table);
     return parent::dropForeignKey($name, $table);
 }
开发者ID:flexibuild,项目名称:migrate,代码行数:9,代码来源:Migration.php

示例4: remove

 public function remove()
 {
     return $this->migrate->dropForeignKey($this->getName(), $this->getSourceTable());
 }
开发者ID:carono,项目名称:yii2-installer,代码行数:4,代码来源:ForeignKeyColumn.php

示例5: dropForeignKey

 /**
  * @inheritdoc
  */
 public function dropForeignKey($name, $table)
 {
     $indexName = $name;
     if (preg_match('/\\}\\}$/', $indexName)) {
         $indexName = preg_replace('/^(.*)\\}\\}$/', '$1_idx}}', $indexName);
     } else {
         $indexName .= '_idx';
     }
     parent::dropForeignKey($name, $table);
     $this->dropIndex($indexName, $table);
 }
开发者ID:nox-it,项目名称:yii2-nox-migration,代码行数:14,代码来源:Migration.php

示例6: dropForeignKey

 /**
  * Builds a SQL statement for dropping a foreign key constraint.
  * @param string $table the table whose foreign is to be dropped. The name will be properly quoted by the method.
  * @param string|array $columns the name of the column to that the constraint will be added on. If there are multiple columns, separate them with commas or use an array.
  * @param string $name the name of the foreign key constraint to be dropped. The name will be properly quoted by the method.
  */
 public function dropForeignKey($table, $columns, $name = null)
 {
     $name = $name ?: $this->getNameForeignKey($table, $columns);
     parent::dropForeignKey($name, $table);
 }
开发者ID:lav45,项目名称:yii2-db-migrate,代码行数:11,代码来源:Migration.php


注:本文中的yii\db\Migration::dropForeignKey方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。