ホームページ > ウェブフロントエンド > jsチュートリアル > 移行を使用した Prisma ワークフローの理解

移行を使用した Prisma ワークフローの理解

王林
リリース: 2024-07-18 04:31:30
オリジナル
994 人が閲覧しました

Entendendo o Fluxo de Trabalho do Prisma Utilizando Migrations

Prisma は、Node.js および TypeScript アプリケーションでのデータベースとの対話を容易にする最新の ORM (オブジェクト リレーショナル マッピング) です。 Prisma の最も重要な機能の 1 つは移行システムです。これにより、データベース スキーマとアプリケーションのデータ モデルの同期を維持できます。この投稿では、移行を使用した Prisma ワークフローについて説明します。

移行とは何ですか?

移行は、体系的かつバージョン管理された方法でデータベース スキーマへの変更を制御および適用するための方法です。これらを使用すると、テーブルの作成や変更など、データベースの構造変更を増分的かつ元に戻せる方法で定義できます。

移行を伴う Prisma ワークフロー

Prisma での移行の一般的なワークフローには、次の手順が含まれます。

  1. インストールと初期設定
  2. スキーム定義
  3. 移行の作成
  4. 移行アプリケーション
  5. 移行管理

ステップ 1: インストールと初期構成

まず、Prisma をプロジェクトにインストールして初期化する必要があります:

npm install @prisma/client
npx prisma init

ログイン後にコピー

このコマンドは、データ モデルを定義する schema.prisma ファイルを含む prism ディレクトリを作成します。

ステップ 2: スキーマの定義

schema.prisma ファイルでは、データベース テーブルを表すモデルを定義します。たとえば、モデル User:
を定義してみましょう。

model User {
  id    Int     @id @default(autoincrement())
  email String  @unique
  name  String?
}

ログイン後にコピー

ここでは、ID、電子メール、名前の列を含む User テーブルを定義しています。

ステップ 3: 移行の作成

スキーマを定義または変更した後、これらの変更をデータベースに反映する移行を作成します。

npx prisma migrate dev --name init

ログイン後にコピー

merge dev コマンドは、新しい移行を作成し、変更をデータベースに適用します。 --name パラメーターを使用すると、上記の例の init など、移行にわかりやすい名前を付けることができます。

ステップ 4: 移行アプリケーション

merge dev コマンドを使用すると、移行はデータベースに自動的に適用されます。これにより、データベースが schema.prisma.

で定義されたデータ モデルと常に同期されることが保証されます。

実稼働環境で移行を適用する場合は、次のコマンドを使用します。

npx prisma migrate deploy

ログイン後にコピー

このコマンドは、保留中のすべての移行を実稼働データベースに適用します。

ステップ 5: 移行管理

Prisma は、データベースに適用されたすべての移行の履歴を保持します。これは、変更を追跡し、必要に応じて移行を元に戻すのに役立ちます。移行履歴を確認するには、次のコマンドを使用できます。

npx prisma migrate status

ログイン後にコピー

このコマンドは、どの移行が適用され、どの移行が保留中であるかを含む、移行の現在のステータスを表示します。

実践例

User モデルに新しいフィールドを追加し、この変更に対する移行を作成する方法の実践的な例を見てみましょう。

  1. schema.prisma の User モデルにフィールドを追加します:

    model User {
      id        Int     @id @default(autoincrement())
      email     String  @unique
      name      String?
      birthdate DateTime?
    }
    
    
    ログイン後にコピー
  2. 新しい移行を作成します:

    npx prisma migrate dev --name add-birthdate-to-user
    
    
    ログイン後にコピー
  3. 移行を適用します:

    merge dev コマンドはすでにデータベースに移行を適用しています。これで、データベースの User テーブルに新しい生年月日フィールドが追加されました。

  4. 移行ステータスを確認する:

    npx prisma migrate status
    
    
    ログイン後にコピー

    このコマンドは、add-birthdate-to-user の移行が正常に適用されたことを示します。

結論

移行を使用した Prisma のワークフローは、データベース スキーマへの変更を管理する効率的かつ安全な方法です。スキーマの定義、移行の作成、変更の適用、移行履歴の管理という明確な一連のステップを通じて、データベースとアプリケーションのデータ モデルの同期を維持することができ、ソフトウェアの開発とメンテナンスが容易になります。

Prisma を使用すると、データベース管理が簡素化されるだけでなく、すべての変更が追跡可能で元に戻せることを保証する強力なツールも得られ、より堅牢で機敏な開発プロセスに貢献します。

以上が移行を使用した Prisma ワークフローの理解の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート