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() − 외래 키 제거