백엔드 개발 PHP 튜토리얼 PHP8.0의 데이터 마이그레이션 라이브러리: Phinx

PHP8.0의 데이터 마이그레이션 라이브러리: Phinx

May 14, 2023 am 10:40 AM
php 데이터 마이그레이션 phinx

인터넷 기술이 발전하고 응용 범위가 확대됨에 따라 데이터 마이그레이션이 점점 더 일반화되고 중요해졌습니다. 데이터 마이그레이션은 기존 데이터베이스 구조와 데이터를 다른 환경이나 새로운 시스템으로 이동하는 프로세스를 의미합니다. 데이터 마이그레이션 프로세스에는 한 데이터베이스 엔진에서 다른 데이터베이스 엔진으로, 한 데이터베이스 버전에서 다른 데이터베이스 버전으로, 다른 데이터베이스 인스턴스로, 또는 한 서버에서 다른 서버로가 포함될 수 있습니다.

PHP 개발 분야에서 Phinx는 널리 사용되는 데이터 마이그레이션 라이브러리입니다. Phinx는 데이터베이스 버전의 자동 업그레이드 및 다운그레이드를 지원하므로 데이터 마이그레이션을 빠르고 쉽게 생성, 배포 및 실행할 수 있습니다. 이번 글에서는 Phinx의 주요 기능과 사용법을 소개하겠습니다.

1. Phinx의 주요 기능

  1. 데이터베이스 엔진 및 버전 지원

Phinx는 MySQL, PostgreSQL, SQL Server, Oracle 등과 같은 주류 데이터베이스 엔진 및 버전을 지원하며 서로 다른 데이터베이스 버전 간의 마이그레이션도 지원합니다. .

  1. Scalability

Phinx는 확장성이 좋으며 laravel-phinx, phinx-seed 등과 같은 플러그인을 통해 더 많은 기능을 구현할 수 있습니다. 다른 데이터 마이그레이션 라이브러리와 달리 Phinx는 다중 연결도 지원하며 다양한 연결 구성을 사용하여 해당 마이그레이션 시나리오에 대처할 수 있습니다.

  1. 데이터 버전 제어

Phinx에는 기본 버전 제어 기능이 제공됩니다. 각 마이그레이션에서는 버전 번호와 상태 정보를 기록하므로 빠르고 쉽게 이전 버전으로 롤백할 수 있습니다.

  1. 데이터 마이그레이션 수명주기

Phinx는 마이그레이션 전, 마이그레이션 중, 마이그레이션 후를 포함하여 데이터 마이그레이션의 전체 수명주기 관리를 제공합니다. 데이터 마이그레이션에는 각 수명 주기마다 수행할 수 있는 다양한 작업이 있습니다.

  1. 데이터 생성

Phinx에서 개발자는 명령을 사용하여 테이블 구조와 마이그레이션 템플릿을 자동으로 생성하여 데이터 마이그레이션을 더욱 편리하고 효율적으로 만들 수 있습니다.

2. Phinx 사용 방법

  1. Phinx 설치

Phinx는 Composer를 통해 설치됩니다.

    composer global require robmorgan/phinx
  1. Configure Phinx

Phinx 구성 파일은 다음 위치에 있어야 합니다. 프로젝트의 루트 디렉터리 다음으로 이름을 phinx.yml로 지정합니다. 구성 파일의 예는 다음과 같습니다.

    paths:
        migrations: %%PHINX_CONFIG_DIR%%/db/migrations
        seeds: %%PHINX_CONFIG_DIR%%/db/seeds

    environments:
        default_database: development
        development:
            adapter: mysql
            host: localhost
            name: my_database
            user: root
            pass: password
            port: 3306
            charset: utf8
  1. 마이그레이션 파일 만들기

Phinx는 마이그레이션 파일을 사용하여 각 마이그레이션의 특정 내용을 설명합니다. 마이그레이션 파일을 실행하면 Phinx가 데이터베이스를 업그레이드하거나 다운그레이드합니다. 마이그레이션 파일은 구성 파일에 구성된 마이그레이션 경로에 위치하며, 파일 이름 형식은 YYYYMMDDHHMMSS_migration_name.php와 같습니다. 여기서 YYYYMMDDHHMMSS는 마이그레이션 파일의 버전 번호를 나타냅니다. 다음 명령을 사용하여 마이그레이션 파일을 생성할 수 있습니다. YYYYMMDDHHMMSS_migration_name.php,其中 YYYYMMDDHHMMSS 表示该迁移文件的版本号。可以使用以下命令生成迁移文件:

    vendor/bin/phinx create MyFirstMigration

生成的迁移文件如下:

    <?php

    use PhinxMigrationAbstractMigration;

    class MyFirstMigration extends AbstractMigration
    {
        public function change()
        {

        }
    }

其中 change()方法是必须的,这里写下具体的迁移操作。

  1. 执行迁移

使用以下命令可以执行迁移:

    vendor/bin/phinx migrate

执行迁移后,将会记录迁移日志,下次执行迁移时会忽略已经执行过的迁移。

  1. 回滚迁移

在开发过程中,可能需要回滚到之前迁移过的一些版本。使用以下命令回滚:

    vendor/bin/phinx rollback

Phinx将会回滚最近的一次迁移。

  1. 生成数据填充文件

Phinx提供了数据填充的功能,使用以下命令生成数据填充文件:

    vendor/bin/phinx seed:create UserSeeder

生成的文件如下:

    <?php

    use PhinxSeedAbstractSeed;

    class UserSeeder extends AbstractSeed
    {
        public function run()
        {

        }
    }

run()

    vendor/bin/phinx seed:run
생성된 마이그레이션 파일은 다음과 같습니다.
    rrreee
  1. change() 메서드가 필요하며, 구체적인 마이그레이션 작업이 여기에 기록됩니다.

Execute migration

마이그레이션을 실행하려면 다음 명령어를 사용하세요.

rrreee

마이그레이션 실행 후 마이그레이션 로그가 기록되며, 다음번 마이그레이션 실행 시 이미 실행된 마이그레이션은 무시됩니다.

🎜롤백 마이그레이션🎜🎜🎜개발 프로세스 중에 이전에 마이그레이션한 일부 버전으로 롤백해야 할 수도 있습니다. 롤백하려면 다음 명령을 사용하세요. 🎜rrreee🎜Phinx는 가장 최근 마이그레이션을 롤백합니다. 🎜
    🎜데이터 채우기 파일 생성🎜🎜🎜Phinx는 데이터 채우기 기능을 제공합니다. 다음 명령을 사용하여 데이터 채우기 파일을 생성합니다. 🎜rrreee🎜생성된 파일은 다음과 같습니다. 🎜rrreee🎜In run( ) 메서드를 사용하여 채우기 논리를 작성합니다. 🎜🎜🎜데이터 채우기 수행🎜🎜🎜다음 명령을 사용하여 데이터 채우기를 수행합니다. 🎜rrreee🎜Phinx는 지정된 채우기 파일을 실행합니다. 🎜🎜요약🎜🎜Phinx는 데이터베이스 엔진 및 버전 지원, 확장성, 데이터 버전 제어 등 많은 기능을 갖춘 매우 사용하기 쉬운 데이터 마이그레이션 라이브러리입니다. Phinx를 사용하면 데이터 마이그레이션을 쉽게 생성, 배포 및 실행할 수 있으므로 데이터 마이그레이션의 전체 수명 주기 관리가 실현되어 개발자의 작업이 더 쉬워집니다. 🎜

위 내용은 PHP8.0의 데이터 마이그레이션 라이브러리: Phinx의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Stock Market GPT

Stock Market GPT

더 현명한 결정을 위한 AI 기반 투자 연구

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

PHP로 데이터베이스에서 레코드를 업데이트하는 방법은 무엇입니까? PHP로 데이터베이스에서 레코드를 업데이트하는 방법은 무엇입니까? Sep 21, 2025 am 04:47 AM

toupdateadaBasereCordInphp, FirstConnectusingpdoorMysqli, whenEseprepredStatementStoExecuteAcureCuresqlupDateQuery.example : $ pdo = newpdo ( "mysql : host = localhost; dbname = your_database", $ username, $ username, $ sql = "squer erestemail);

PHP에서 파일 권한을 확인하는 방법은 무엇입니까? PHP에서 파일 권한을 확인하는 방법은 무엇입니까? Sep 22, 2025 am 06:27 AM

usefileperms () togetFilePermissAnintegerAntegerandFormatItSprintf ( '%o') toDisplayUnix-StylePerMissions0644. usePracticalAccessChecks, useIS_Readable (), is_writable (), oris_executable (), witeReTreftecanread, witeRetherfilecanread

PHP 스크립트에서 명령 줄 인수를 얻는 방법은 무엇입니까? PHP 스크립트에서 명령 줄 인수를 얻는 방법은 무엇입니까? Sep 22, 2025 am 06:19 AM

$ argv 및 $ argc를 사용하여 PHP 명령 줄 매개 변수를 얻습니다. $ argc는 매개 변수 수이며 $ argv는 매개 변수 배열입니다. 예를 들어, phpsscript.phphelloworld, $ argv = [ 'script.php', 'hello', 'world']; 특정 매개 변수에 액세스하기 위해 $ argv [1]를 사용합니다. getOpt ()를 사용하여 복잡한 시나리오에서 짧은 옵션 (-f) 및 긴 옵션 (-File)을 처리하십시오.

PHP에서 싱글 톤 패턴을 구현하는 방법은 무엇입니까? PHP에서 싱글 톤 패턴을 구현하는 방법은 무엇입니까? Sep 25, 2025 am 12:27 AM

싱글 톤 패턴은 클래스에 인스턴스가 하나만 있고 단일 객체가 데이터베이스 연결 또는 구성 관리와 같은 시스템 작동을 조정하는 시나리오에 대한 글로벌 액세스 포인트를 제공합니다. 2. 기본 구조에는 다음이 포함됩니다. 개인 정적 속성 저장 인스턴스, 개인 생성기는 외부 생성을 방지, 개인 복제 방법을 복사하지 못하고 인스턴스를 얻기위한 공개 정적 방법 (getInstance ()). 3. getInstance () 메소드를 호출하여 PHP에서 고유 한 인스턴스를 얻고 몇 번이나 호출 되더라도 동일한 개체 참조를 반환합니다. 4. 표준 PHP 요청 모델에서 스레드 안전을 고려할 필요는 없지만, 동기화 문제는 장기 또는 다중 스레드 환경에서주의를 기울여야하며 PHP 자체는 기본 잠금 메커니즘을 지원하지 않습니다. 5. 싱글 톤은 유용하지만

PHP에서 Null Coalescing 연산자 (??)을 사용하는 방법? PHP에서 Null Coalescing 연산자 (??)을 사용하는 방법? Sep 25, 2025 am 01:28 AM

답변 : PHP의 빈 합병 연산자 (??)은 변수 또는 배열 키가 존재하고 무효가 아닌지 확인하는 데 사용됩니다. 사실이라면 값을 반환하고 그렇지 않으면 기본값을 반환합니다. 긴 ISSET () 점검을 사용하는 것을 피하고, $ username = $ userInput ?? 'Guest'와 같은 정의되지 않은 변수 및 배열 키를 처리하는 데 적합하며, $ teme = $ usertheme ?? $ defaulttheme ?? 'Dark'와 같은 체인 호출을 지원합니다. 양식, 구성 및 사용자 입력에 특히 적합한 경우, emull values, emply vallys, emply values, excluds and excluds is allud valluds is allud valluds.

PHP에서 URL 매개 변수를 얻는 방법은 무엇입니까? PHP에서 URL 매개 변수를 얻는 방법은 무엇입니까? Sep 24, 2025 am 05:11 AM

$ _get을 사용하여? name = john & age = 25와 같은 URL 매개 변수를 얻습니다. ISSET 또는 빈 병합 연산자를 통해 존재를 점검하고 Filter_Input로 데이터를 필터링하고 확인하여 보안을 보장하십시오.

PHP에서 zip 파일을 만드는 방법? PHP에서 zip 파일을 만드는 방법? Sep 22, 2025 am 06:06 AM

usetheziparchiveclasStocreateazipfileinphpbyinstantiatingtheObject, OpeningThearchWithOpen (), addingFilesViaAddFile () oraddfromString () 및 ClosingItwithClose () tosave; 항상 CheckoPen () ReturnValueAnderePermissions.

PHP에서 JSON 객체를 만드는 방법? PHP에서 JSON 객체를 만드는 방법? Sep 22, 2025 am 04:13 AM

JSON_ENCODE () 함수를 사용하여 PHP 배열 또는 객체를 JSON 문자열로 변환하십시오. 예를 들어, 연관 배열 [ "name"=> "john", "age"=> 30, "city"=> "newyork"] 출력 { "name": "John", "Age": 30, "City": "Newyork & &"

See all articles