Yii-데이터베이스 마이그레이션

데이터베이스 기반 애플리케이션을 개발하는 동안 데이터베이스 구조는 소스 코드와 함께 발전합니다. Yii는database migration 데이터베이스 변경 사항을 추적 할 수있는 기능입니다.

Yii는 다음 마이그레이션 명령 줄 도구를 제공합니다.

  • 새 마이그레이션 만들기
  • 마이그레이션 되돌리기
  • 마이그레이션 적용
  • 마이그레이션 다시 적용
  • 마이그레이션 상태 및 기록 표시

마이그레이션 생성

새 데이터베이스 마이그레이션을 만들어 보겠습니다.

Step 1 − 기본 애플리케이션 템플릿의 프로젝트 루트 내에서 콘솔 창을 열고 실행합니다.

./yii migrate/create add_news_table

위의 명령은 새 마이그레이션 파일 (이 경우 m160113_102634_add_news_table.php)을 migrations 폴더.

파일에는 다음 코드가 포함되어 있습니다.

<?php
   use yii\db\Schema;
   use yii\db\Migration;
   class m160113_102634_add_news_table extends Migration {
      public function up() {
   
      }
      public function down() {
         echo "m160113_102634_add_news_table cannot be reverted.\n";
         return false;
      }
      /*
      // Use safeUp/safeDown to run migration code within a transaction
      public function safeUp() {
 
      }
      public function safeDown() {
   
      }
      */
   }
?>

각 DB 마이그레이션은 yii\db\Migration수업. 클래스 이름은 다음 형식으로 생성됩니다.

m<YYMMDD_HHMMSS>_<Name>

어디 <YYMMDD_HMMSS> 마이그레이션 명령이 실행 된 UTC 날짜 시간이고 <Name>은 콘솔 명령에서 제공 한 인수입니다.

up () 메서드는 데이터베이스를 업그레이드 할 때 호출되고 down () 메서드는 다운 그레이드 할 때 호출됩니다.

Step 2 − 데이터베이스에 새 테이블을 추가하려면이 방법으로 마이그레이션 파일을 수정하십시오.

<?php
   use yii\db\Schema;
   use yii\db\Migration;
   class m160113_102634_add_news_table extends Migration {
      public function up() {
         $this->createTable("news", [ "id" => Schema::TYPE_PK, "title" => Schema::TYPE_STRING, "content" => Schema::TYPE_TEXT, ]); } public function down() { $this->dropTable('news');
      }
      /*
      // Use safeUp/safeDown to run migration code within a transaction
      public function safeUp() {
	
      }
      public function safeDown() {

      }
      */
   }
?>

위의 코드에서 뉴스라는 새 테이블을 up() 메소드를 사용하고이 테이블을 down() 방법.

그만큼 news테이블은 id, title 및 content의 세 필드로 구성됩니다. 테이블 또는 열을 만들 때 마이그레이션이 데이터베이스 유형과 독립적이되도록 추상 유형을 사용해야합니다. 예를 들어, MySQL의 경우 TYPE_PK는 int (11) NOT NUL AUTO_INCREMETN PRIMARY KEY로 변환됩니다.

Step 3 − 데이터베이스를 업그레이드하려면이 명령을 실행하십시오.

./yii migrate

위의 명령은 아직 적용되지 않은 사용 가능한 모든 마이그레이션을 나열합니다. 그런 다음 마이그레이션 적용을 확인하면 모든 새 마이그레이션 클래스에서 safeUp () 또는 up ()이 실행됩니다.

Step 4 − 사용 가능한 마이그레이션을 3 개만 적용하려면 실행할 수 있습니다.

./yii migrate 3

Step 5 − 또한 데이터베이스를 마이그레이션해야하는 특정 마이그레이션을 정의 할 수도 있습니다.

# 타임 스탬프를 사용하여 마이그레이션 지정

yii migrate/to 160202_195501

# strtotime ()으로 구문 분석 할 수있는 문자열 사용

yii migrate/to "2016-01-01 19:55:01"

# 전체 이름 사용

yii migrate/to m160202_195501_create_news_table

# UNIX 타임 스탬프 사용

yii migrate/to 1393964718

Step 6 − 마이그레이션 (execute down () 또는 safeDown () 메소드)을 되돌리려면 다음을 실행하십시오.

./yii migrate/down

Step 7 − 가장 최근에 적용된 5 개의 마이그레이션을 되돌리려면 다음을 실행할 수 있습니다.

./yii migrate/down 5

Step 8 − 마이그레이션을 다시 실행 (되 돌린 후 다시 적용)하려면 실행하십시오.

./yii migrate/redo

이미 적용된 마이그레이션을 나열하려면 다음 명령을 사용하십시오.

  • yii migrate/new #은 처음 10 개의 새로운 마이그레이션을 보여줍니다.

  • yii migrate/new 3 #은 처음 3 개의 새로운 마이그레이션을 보여줍니다.

  • yii migrate/new all # 모든 새 마이그레이션을 표시합니다.

  • yii migrate/history #은 마지막으로 적용된 마이그레이션 10 개를 보여줍니다.

  • yii migrate/history 20 #은 최근 적용된 마이그레이션 20 개를 보여줍니다.

  • yii migrate/history all # 적용된 모든 마이그레이션을 표시합니다.

때로는 특정 테이블에서 열을 추가하거나 삭제해야합니다. 당신이 사용할 수있는addColumn()dropColumn() 행동 양식.

Step 1 − 새 마이그레이션을 생성합니다.

./yii migrate/create add_category_to_news

Step 2 − 새로 생성 된 마이그레이션 파일을 이런 방식으로 수정합니다.

<?php
   use yii\db\Schema;
   use yii\db\Migration;
   class m160113_110909_add_category_to_news extends Migration {
      public function up() {
         $this->addColumn('news', 'category', $this->integer());
      }
      public function down() {
         $this->dropColumn('news', 'category');
      }
   }
?>

이제 실행하면 ./yii migrate, 카테고리 열이 뉴스 테이블에 추가되어야합니다. 반대로 달리면./yii migrate/down 1, 카테고리 열을 삭제해야합니다.

DB 마이그레이션을 수행 할 때 각 마이그레이션이 성공 또는 실패했는지 확인하는 것이 중요합니다. 트랜잭션에 DB 작업을 포함하는 것이 좋습니다. 트랜잭션 마이그레이션을 구현하려면 마이그레이션 코드를safeUp()safeDown()행동 양식. 이러한 메서드의 작업이 실패하면 이전 작업이 모두 롤백됩니다.

"트랜잭션 방식"의 이전 예는 다음과 같습니다.

<?php
   use yii\db\Schema;
   use yii\db\Migration;
   class m160113_110909_add_category_to_news extends Migration {
      public function safeUp() {
         $this->addColumn('news', 'category', $this->integer()); } public function safeDown() { $this->dropColumn('news', 'category');
      }
   }
?>

그만큼 yii\db\Migration 클래스는 데이터베이스를 조작하기 위해 다음과 같은 방법을 제공합니다-

  • execute() − 원시 SQL 문을 실행합니다.

  • createTable() − 테이블 생성

  • renameTable() − 테이블 이름 변경

  • insert() − 단일 행 삽입

  • batchInsert() − 여러 행 삽입

  • update() − 행 업데이트

  • delete() − 행 삭제

  • addColumn() − 열 추가

  • renameColumn() − 열 이름 변경

  • dropColumn() − 열 제거

  • alterColumn() − 열 변경

  • dropTable() − 테이블을 제거합니다.

  • truncateTable() − 테이블의 모든 행을 제거합니다.

  • createIndex() − 인덱스 생성

  • dropIndex() − 색인을 제거합니다.

  • addPrimaryKey() − 기본 키 추가

  • dropPrimaryKey() − 기본 키 제거

  • addForeignKey() − 외래 키 추가

  • dropForeignKey() − 외래 키 제거