「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 移行を使用した Prisma ワークフローの理解

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

2024 年 8 月 18 日に公開
ブラウズ:264

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

リリースステートメント この記事は次の場所に転載されています: https://dev.to/lemartin07/entendendo-o-fluxo-de-trabalho-do-prisma-utilizando-migrations-29cp?1 権利侵害がある場合は、[email protected] までご連絡ください。それを削除するには
最新のチュートリアル もっと>
  • Pythonのみを使用してフロントエンドを構築する
    Pythonのみを使用してフロントエンドを構築する
    バックエンドに重点を置く開発者にとって、フロントエンド開発は困難な、さらには悪夢のような作業になる可能性があります。私のキャリアの初期には、フロントエンドとバックエンドの境界があいまいで、誰もが両方を扱うことが期待されていました。特に CSS は絶えず苦労しました。不可能なミッションのように感じまし...
    プログラミング 2024 年 11 月 5 日に公開
  • LaravelでCronジョブを実行する方法
    LaravelでCronジョブを実行する方法
    このチュートリアルでは、Laravel で cron ジョブを実行する方法を説明しますが、何よりも生徒にとって物事をシンプルで簡単なものにします。 Laravel アプリを構築しながら、これらの自動化されたタスクを自分のコンピューター上でセットアップして実行する方法を検討していきます。 まず、cr...
    プログラミング 2024 年 11 月 5 日に公開
  • パディングはインライン要素の間隔にどのような影響を与えますか?また、競合はどのように解決できますか?
    パディングはインライン要素の間隔にどのような影響を与えますか?また、競合はどのように解決できますか?
    インライン要素のパディング: 効果と制限ソースによると、インライン要素の上部と下部にパディングを追加しても影響はありません周囲の要素の間隔。ただし、「パディングは他のインライン要素と重なる」という記述は、パディングが影響を与える特定の状況がある可能性があることを示唆しています。オーバーラップ パディ...
    プログラミング 2024 年 11 月 5 日に公開
  • Django クラスベースのビューが簡単に
    Django クラスベースのビューが簡単に
    ご存知のとおり、django は Web アプリケーション開発の設計に MVT (model-view-template) を使用します。 View 自体は、リクエストを受け取り、レスポンスを返す呼び出し可能です。 Django はクラス ベース ビューと呼ばれるものを提供するため、これは単なる機...
    プログラミング 2024 年 11 月 5 日に公開
  • VAKX を使用してノーコード AI エージェントを構築する
    VAKX を使用してノーコード AI エージェントを構築する
    If you’ve been keeping up with the AI space, you already know that AI agents are becoming a game-changer in the world of automation and customer inter...
    プログラミング 2024 年 11 月 5 日に公開
  • ここでは、jQuery Datatable でカーソルベースのページネーションを実装する方法を説明します。
    ここでは、jQuery Datatable でカーソルベースのページネーションを実装する方法を説明します。
    Web アプリケーションで大規模なデータセットを操作する場合、ページネーションはパフォーマンスとユーザー エクスペリエンスにとって非常に重要です。データ テーブルで一般的に使用される標準のオフセット ベースのページネーションは、大規模なデータセットでは非効率的になる可能性があります。 カーソルベー...
    プログラミング 2024 年 11 月 5 日に公開
  • 同期エンジンが Web アプリケーションの未来となる理由
    同期エンジンが Web アプリケーションの未来となる理由
    進化する Web アプリケーションの世界では、効率、スケーラビリティ、シームレスなリアルタイム エクスペリエンスが最も重要です。従来の Web アーキテクチャは、クライアント/サーバー モデルに大きく依存しており、応答性と同期に対する現代の要求の下では困難になる可能性があります。ここで同期エンジンが...
    プログラミング 2024 年 11 月 5 日に公開
  • Python によるコンピューター ビジョンの概要 (パート 1)
    Python によるコンピューター ビジョンの概要 (パート 1)
    注: この投稿では、わかりやすくするためにグレースケール画像のみを使用します。 画像とは何ですか? 画像は値の行列として考えることができ、各値はピクセルの強度を表します。画像形式には主に 3 つのタイプがあります: Binary: この形式の画像は、0 (黒) と 1 (白) の値を...
    プログラミング 2024 年 11 月 5 日に公開
  • ウェブサイトのHTMLコード
    ウェブサイトのHTMLコード
    航空関連のウェブサイトを構築しようとしています。 AI を使用してコードを生成し、Web サイト全体を生成できるかどうかを確認したかっただけです。 HTML Web サイトはブログと互換性がありますか? それとも JavaScript を使用する必要がありますか?これがデモとして使用したコードです。...
    プログラミング 2024 年 11 月 5 日に公開
  • プログラマーのように考える: Java の基礎を学ぶ
    プログラマーのように考える: Java の基礎を学ぶ
    この記事では、Java プログラミングの基本的な概念と構造を紹介します。変数とデータ型の紹介から始まり、演算子と式、および制御フロー プロセスについて説明します。次に、メソッドとクラスについて説明し、次に入出力操作を紹介します。最後に、この記事では、給与計算の実際の例を通じて、これらの概念の適用を示...
    プログラミング 2024 年 11 月 5 日に公開
  • PHP GD は 2 つの画像の類似性を比較できますか?
    PHP GD は 2 つの画像の類似性を比較できますか?
    PHP GD は 2 つの画像の類似性を判断できますか?検討中の質問は、次の方法を使用して 2 つの画像が同一であるかどうかを確認できるかどうかを尋ねます。 PHP GD の違いを比較します。これには、2 つの画像の差を取得し、画像全体が白 (または均一な色) で構成されているかどうかを判断する必要...
    プログラミング 2024 年 11 月 5 日に公開
  • これらのキーを使用して上級レベルのテストを作成します (JavaScript でのテスト要求)
    これらのキーを使用して上級レベルのテストを作成します (JavaScript でのテスト要求)
    この記事では、すべての上級開発者が知っておくべき 12 のテストのベスト プラクティスを学びます。 Kent Beck の記事「Test Desiderata」は Ruby で書かれているため、実際の JavaScript の例が表示されます。 これらのプロパティは、より良いテストを作成できるように...
    プログラミング 2024 年 11 月 5 日に公開
  • matlab/octave アルゴリズムを C に移植することによる AEC への最適なソリューション
    matlab/octave アルゴリズムを C に移植することによる AEC への最適なソリューション
    終わり!自分自身に少し感動しました。 当社の製品にはエコーキャンセル機能が必要であり、考えられる技術的解決策が 3 つ特定されました。 1) MCU を使用してオーディオ信号のオーディオ出力とオーディオ入力を検出し、オプションの 2 つのチャネル切り替えの間のオーディオ出力とオーディオ入力の強度に応...
    プログラミング 2024 年 11 月 5 日に公開
  • Web ページを段階的に構築する: HTML の構造と要素を調べる
    Web ページを段階的に構築する: HTML の構造と要素を調べる
    ?今日は、私のソフトウェア開発の旅において重要なステップとなります。 ?私は最初のコード行を書き、HTML の本質を掘り下げました。対象となる要素とタグ。昨日は、Web サイトを構造化するためのボックス化テクニックを検討しました。そして今日は、ヘッダー、フッター、コンテンツ領域などのセクションを作成...
    プログラミング 2024 年 11 月 5 日に公開
  • プロジェクトのアイデアはユニークである必要はありません: その理由は次のとおりです
    プロジェクトのアイデアはユニークである必要はありません: その理由は次のとおりです
    イノベーションの世界では、プロジェクトのアイデアが価値があるためには革新的であるか、完全にユニークである必要があるという誤解がよくあります。しかし、それは真実とは程遠いです。私たちが今日使用している成功した製品の多くは、主要な機能セットを競合他社と共有しています。彼らを区別するのは必ずしもアイデアで...
    プログラミング 2024 年 11 月 5 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3