検索
ホームページバックエンド開発PHPチュートリアルDBVを使用したデータベースバージョン

DBVを使用したデータベースバージョン

キーテイクアウト

  • DBVは、MySQLデータベース用のPHPベースのデータベースバージョン制御システムです。スタンドアロンではなく、チームとの変更を同期するためにGit、Mercurial、またはSVNなどのバージョン制御システムが必要です。
  • DBVを使用すると、開発者はデータベースに加えられた変更を追跡し、これらの変更をチームメンバーと共有し、全員がデータベースの最新のコピーを使用していることを確認できます。新しいテーブル、改名またはドロップされたテーブル、新規または更新されたフィールド、新規または更新されたテーブルの行などの変更を追跡できます。
  • DBVワークフローには、データベースのローカルコピーを作成し、変更を加え、これらの変更をディスクにエクスポートし、ソースコントロールにコミットし、中央リポジトリにプッシュすることが含まれます。チームメンバーは、これらの変更をローカルコピーに引くことができます。
  • DBVは改訂もサポートしており、開発者が複数のテーブルの構造を変更できるようにします。ただし、変更が相互に関連していない限り、単一のテーブルに変更を加えて改訂することをお勧めします。
  • プロジェクトのいずれかで常にバージョン制御システムを使用することをお勧めします。それはあなたが唯一の開発者であるサイドプロジェクトであろうと、5人以上が一緒に作業しているチームプロジェクトです。しかし、データベースをバージョン制御に入れるというアイデアは、それほど広くはありません。多くの場合、データベースを当然のことと考えています。
しかし、プロジェクトのソースファイルと同様に、データベースも常に変化しています。そのため、行った変更を追跡し、チームの他のメンバーと簡単に共有する方法も必要です。

この記事では、MySQLデータベースのPHPで記述されているデータベースバージョン制御システムであるDBVを見て、ApacheやNginxなどのWebサーバーとともにPHPとMySQLを使用する前にインストールする必要があります。

このソフトウェアに関する重要な注意は、チームとの変化を同期するためにGIT、Mercurial、SVNなどのバージョン制御システムが必要であるため、スタンドアロンのデータベースバージョン制御システムではないことです。

dbv

のインストール

DBVの作業を開始するには、最初にWebサイトからインストーラーをダウンロードし、プロジェクトディレクトリに抽出し、結果のフォルダーをDBVに変更する必要があります。これにより、次のパスが得られます

別のアプローチは、Githubからクローニングするだけです

dbv構成

config.php.sampleファイルのコピーを作成し、config.phpに変更することにより、DBVのオプションの構成を開始できます。

ここで更新する最も重要なことは、最初の2つのセクションです。現在のデータベース構成の値について、my_username、my_password、my_databaseの値を置き換えるだけです。

<span>my_project/dbv</span>
上記の構成ファイルの最初のセクションは、マシン内のMySQLデータベースの詳細に関するすべてです。

2番目のセクションは、DBV自体のログイン詳細です。

次に.gitignoreファイルを開きます。デフォルトでは、次のものが含まれています

<span>my_project/dbv</span>
これらは、Gitで無視されるファイルです。ただし、チームメイトと同じデータベース情報(ユーザー、パスワード、データベース名)があることがわかっている場合は、.gitignoreファイルからconfig.phpを削除できます。そうでない場合は、独自の構成ファイルを作成し、ソースコントロールから除外する必要があります。

次に、DBVがデータベースのローカルコピーに関する情報を入力するため、データ/メタ/リビジョンファイルを.gitignoreに追加する必要があります。チームメイトにとっては違うかもしれないので、ソースコントロールから除外する必要があります。

構成が完了したら、DBVをバージョンコントロールに追加できるようになりました。

そして、それをあなたのチームの他のメンバーが引っ張るためにあなたの中央リポジトリにそれを押します:

<span><span><?php </span></span><span><span>/**
</span></span><span><span> * Your database authentication information goes here
</span></span><span><span> * <span>@see http://dbv.vizuina.com/documentation/
</span></span></span><span><span> */
</span></span><span><span>define('DB_HOST', 'localhost');
</span></span><span><span>define('DB_PORT', 3306);
</span></span><span><span>define('DB_USERNAME', 'my_username');
</span></span><span><span>define('DB_PASSWORD', 'my_password');
</span></span><span><span>define('DB_NAME', 'my_database');
</span></span><span>
</span><span><span>/**
</span></span><span><span> * Authentication data for access to DBV itself
</span></span><span><span> * If you leave any of the two constants below blank, authentication will be disabled
</span></span><span><span> * <span>@see http://dbv.vizuina.com/documentation/#optional-settings
</span></span></span><span><span> */
</span></span><span><span>define('DBV_USERNAME', 'my_username');
</span></span><span><span>define('DBV_PASSWORD', 'my_password');
</span></span><span><span>?></span></span></span>
追跡するためにどのような変更がありますか

実際にDBVを使用して進む前に移動します。追跡するために変更について少し触れたいと思います。データベースの世界では、ほとんどすべての変更をソースコントロールに入れることができます。これには、次のものが含まれます。
<span>config.php
</span><span>.buildpath
</span><span>.project
</span><span>.settings</span>

新しいテーブル

改名された表
  • テーブルをドロップしました
  • 新しいフィールド
  • 更新されたフィールド
  • 削除されたフィールド
  • 新しいテーブル行(デフォルトのテーブルデータ)
  • 更新されたテーブル行
  • 削除されたテーブル行
  • ビュー
  • ストアドプロシージャ
  • トリガー
  • 関数(ユーザー定義の関数)
  • dbvワークフロー
  • 次のURLにアクセスして、ブラウザからDBVを起動できます。

または仮想ホストを定義した場合、そのURLにアクセスして。

これにより、次のようなインターフェイスが得られます。

<span>git add dbv
</span><span>git commit -m "add dbv into project"</span>
上のスクリーンショットから、以前にconfig.phpで提供したデータベースに現在あるテーブルが表示されます。また、特定のテーブルが現在データベースに含まれているかどうか、および現在のテーブルがファイルシステムに保存されているかどうかを表示するDiskのかどうかを表示するDBフィールドもあります。この情報を使用すると、現在データベースの最新のコピーがあるかどうかをよく知っています。

DBVを使用するときに覚えておくべき重要なことは、データベースのローカルコピーに変更した変更には、ソースコントロールにコミットできるローカルコピーがあることです。

それは、データベースに新しいテーブルを作成する場合、ディスクにエクスポートする必要があることを意味します。ディスクにエクスポートされるすべてのテーブルは、DBVインストールのデータ/スキーマディレクトリに保存されます。以下のスクリーンショットから、現在ファイルシステムにtbl_leadinfoテーブルがないことがわかります。

DBVを使用したデータベースバージョン新しく作成されたテーブルをディスクにエクスポートした後、バージョンコントロールにコミットする必要があります:

<span>my_project/dbv</span>

その後、中央リポジトリに押し込むことができます:

<span><span><?php </span></span><span><span>/**
</span></span><span><span> * Your database authentication information goes here
</span></span><span><span> * <span>@see http://dbv.vizuina.com/documentation/
</span></span></span><span><span> */
</span></span><span><span>define('DB_HOST', 'localhost');
</span></span><span><span>define('DB_PORT', 3306);
</span></span><span><span>define('DB_USERNAME', 'my_username');
</span></span><span><span>define('DB_PASSWORD', 'my_password');
</span></span><span><span>define('DB_NAME', 'my_database');
</span></span><span>
</span><span><span>/**
</span></span><span><span> * Authentication data for access to DBV itself
</span></span><span><span> * If you leave any of the two constants below blank, authentication will be disabled
</span></span><span><span> * <span>@see http://dbv.vizuina.com/documentation/#optional-settings
</span></span></span><span><span> */
</span></span><span><span>define('DBV_USERNAME', 'my_username');
</span></span><span><span>define('DBV_PASSWORD', 'my_password');
</span></span><span><span>?></span></span></span>
この時点で、チームメイトにデータベースに新しいテーブルを作成し、すでに中央のリポジトリにプッシュしたことをチームメイトに伝えることができます。今、彼らはそれを地元のコピーに引き下げることができます。

次に、チームメイトにDBVページ(http:// localhost/your_project/dbv)にアクセスするように伝えます。
<span>config.php
</span><span>.buildpath
</span><span>.project
</span><span>.settings</span>
あなたのチームメイトはおそらく次のような画面を持っています:


この時点で、TBL_TASKSテーブルの横にあるチェックボックスをチェックし、[データベースにプッシュ]ボタンをクリックするだけです。これにより、データベースにtbl_tasksテーブルが作成されます DBVを使用したデータベースバージョンそして、それがDBVで作業するためのワークフローです。とても簡単ですね。しかし、現在のデータベーススキーマを変更する必要がある場合はどうでしょうか?チームに配布する前に、フィールドを逃したり、特定のテーブルにそれを追加するのを忘れていたかもしれません。それが改訂が始まる場所です。

改訂

あなたが私のようで、スキーマを更新しようとした場合(新しいフィールドを追加し、フィールドを削除し、データ型を更新するなど)、DBVがそれを認識していないことに気づいたかもしれません。デフォルト。これらの変更については、リビジョンファイルを作成する必要があります。 DBVインストールのData/Revisions Directoryに新しいフォルダーを作成することで、これを行うことができます。フォルダーに名前を付けるためのコンベンションは、番号を使用しています。したがって、初めてリビジョンを作成すると、フォルダー名は1になり、次に2になります。リビジョンは、データベース全体に適用できる変更であることに注意してください。これは、複数のテーブルの構造を自由に変更する自由があることを意味しますが、単一のテーブルに変更を加えてそれを改訂することのみを行うことができます。これは、あなたとあなたのチームが変更を簡単に管理し、後でそれを理解するためのものです。このプラクティスの唯一の例外は、変更が互いに関連している場合です。その場合、それらの変更を1つの改訂にまとめることは理にかなっています。

TBL_USERSテーブル内に新しいフィールドを作成してみましょう。

次に、DBVインストールにデータ/リビジョン/1ディレクトリに新しいファイルを作成し、コンテンツとして実行したクエリを配置します。ファイルtbl_users.sqlに名前を付けます。ここでの条約は、修正されたテーブルの名前を改訂ファイルの名前として使用しています。

複数のテーブルを変更している場合は、各テーブルの別のファイルを作成します。 その後、新しいファイルをソースコントロールにコミットすることができます:

そして、それを中央のリポジトリに押します:

<span>git add dbv
</span><span>git commit -m "add dbv into project"</span>
繰り返しますが、特定の変化についてチームメイトに通知することができます。データベースを変更する際の通信が重要です。あなたはあなたのチームの全員があなたと同じページにいることを確認したい。

ブラウザからDBVにアクセスすると、改訂が表示されます。彼らが今しなければならないのは、リビジョンの横にチェックボックスをチェックしてから、[選択した改訂を実行]ボタンをクリックすることです。これにより、ローカルデータベースのコピーに変更が取得されます:

DBVを使用したデータベースバージョン

結論

DBVは、データベースバージョンの制御ニーズを簡単に管理するための優れた方法です。それにより、あなたとあなたのチームはあなたのデータベースで行われた変更を簡単に追跡できます。また、Gitを使用して、チームの他のチームと変更を簡単に共有できるようになります。これにより、誰もが常にデータベースの最新のコピーを持っていることが保証されます。 この記事では、GITでDBVを使用することを検討しましたが、選択したバージョン制御システムをほとんど使用できます。フィードバック?以下のコメントに残してください!

データベースバージョンの質問

に関する質問がよくあります

データベースバージョンの主な利点は何ですか?

​​

データベースバージョンはいくつかの利点を提供します。まず、データベーススキーマに加えられたすべての変更の歴史的記録を提供します。これは、デバッグや監査の目的に役立ちます。第二に、エラーや問題の場合に変更を簡単にロールバックできるようになります。第三に、全員が同じバージョンのデータベースを使用していることを確認することにより、チームメンバー間のコラボレーションを促進します。最後に、特に分散型開発環境で、データベースの一貫性と整合性を維持するのに役立ちます。

データベースのバージョン化は実際にどのように機能しますか?データベーススキーマの。これは通常、GITなどのバージョン制御システムを使用して行われます。データベーススキーマへの各変更は、バージョン制御システムの新しいバージョンとしてコミットされます。これらのバージョンは、必要に応じてさまざまな環境(開発、テスト、生産など)でデータベーススキーマを更新するために使用されます。データベースバージョンのバージョンに利用できるツール。人気のあるものには、リキバーゼ、フライウェイ、dbmaestroが含まれます。これらのツールは、自動化されたスキーマの更新、ロールバック機能、複数のデータベースタイプのサポートなどの機能を提供します。ツールの選択は、開発チームの特定の要件と好みに依存します。

データベースバージョンの実装における課題は何ですか?

​​

データベースバージョンの実装は、いくつかの理由により挑戦的です。第一に、開発プロセスの変更が必要であり、管理が困難な場合があります。第二に、データの損失や腐敗を避けるために、データベースの移行を慎重に処理する必要があります。最後に、データベーススキーマとそれに加えられている変更を十分に理解する必要があります。

データベースのバージョン化は、アジャイル開発にどのように役立つことができますか?

アジャイル開発では、変更は頻繁かつ迅速に行われます。データベースのバージョン化は、すべての変更の履歴記録を提供し、変更の簡単なロールバックを促進し、さまざまな環境で一貫性を確保することにより、これらの変更を効果的に管理するのに役立ちます。これにより、開発プロセスの俊敏性と効率性が大幅に向上します。

データベースバージョンのバージョンは、DevOpsにどのように関連していますか?データベースの変更の(CI/CD)。データベーススキーマのバージョン履歴を維持することにより、さまざまな環境にわたる変更の自動展開が可能になり、DevOpsプロセスの速度と効率が向上します。

はい、データベースバージョンはクラウドデータベースで使用できます。ほとんどのデータベースバージョン化ツールは、クラウドデータベースを含む幅広いデータベースタイプをサポートしています。ただし、特定の機能と機能は、ツールとクラウドデータベースの種類によって異なる場合があります。

データガバナンスにおけるデータベースバージョンの役割は何ですか?データベーススキーマの整合性と一貫性を確保することにより、データガバナンス。これは、すべての変更の歴史的記録を提供します。これは、監査やコンプライアンスの目的に役立ちます。また、効果的なデータガバナンスに不可欠なチームメンバー間のコラボレーションとコミュニケーションも促進します。

データベースバージョンのバージョンはデータベースのパフォーマンスをどのように改善できますか?スキーマの変更の履歴記録を提供することにより、パフォーマンスの問題を特定するのに役立ちます。これは、デバッグやパフォーマンスの調整に役立ちます。さらに、データベーススキーマの一貫性と整合性を確保することにより、データベースのパフォーマンスの向上に間接的に貢献できます。含める:バージョン制御システムを使用して、データベーススキーマのバージョン履歴を維持する。各変更を新しいバージョンとしてコミットします。展開前に各バージョンを徹底的にテストします。スキーマの更新とロールバックに自動化されたツールを使用します。チームメンバー間の優れたコミュニケーションとコラボレーションを維持しています

以上がDBVを使用したデータベースバージョンの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPはユーザーのセッションをどのように識別しますか?PHPはユーザーのセッションをどのように識別しますか?May 01, 2025 am 12:23 AM

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションを保護するためのベストプラクティスは何ですか?PHPセッションを保護するためのベストプラクティスは何ですか?May 01, 2025 am 12:22 AM

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

PHPセッションファイルはデフォルトで保存されていますか?PHPセッションファイルはデフォルトで保存されていますか?May 01, 2025 am 12:15 AM

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra

PHPセッションからデータをどのように取得しますか?PHPセッションからデータをどのように取得しますか?May 01, 2025 am 12:11 AM

toretrievedatafrompsession、Startthessession withsession_start()andAccessvariablesshe $ _SessionArray.forexample:1)Startthessession:session_start()

セッションを使用してショッピングカートを実装するにはどうすればよいですか?セッションを使用してショッピングカートを実装するにはどうすればよいですか?May 01, 2025 am 12:10 AM

セッションを使用して効率的なショッピングカートシステムを構築する手順には、次のものがあります。1)セッションの定義と機能を理解します。セッションは、リクエスト全体でユーザーのステータスを維持するために使用されるサーバー側のストレージメカニズムです。 2)ショッピングカートに製品を追加するなど、基本的なセッション管理を実装します。 3)製品の量管理と削除をサポートし、高度な使用状況に拡大します。 4)セッションデータを持続し、安全なセッション識別子を使用することにより、パフォーマンスとセキュリティを最適化します。

PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。