1. PHP がデータベースとして mysql を選択するのはなぜですか?
2. MySQL データベースのユーザーを作成する
この記事は、主にユーザーを作成するための MySQL のステートメントの違いについて書いています。isher の blogspot から転送したものです。なぜ PHP がデータベースとして MySQL を選択するのかを Google で調べてみました。同時に、この問題は私の個人的な意見であり、間違っている点があれば指摘してください。
PHP がデータベースとして mysql を選択するのはなぜですか?
mysql は最も初期のオープンソース データベースです (GPL、GPL2 オープンソース規約に基づいて開発され、共有原則が享受されており、既存の一部は商用利用が計画されています) 無料ですが、そのパフォーマンスと安定性は劣っていません。他の商用データベース、PHP は C 言語に最も近いプログラムとして敷居が低く、商用サーバーに依存しない無料モジュールとして公開されているものが多くあります。したがって、PHP 開発者は、同様に GPL 規約に基づいて開発された Mysql データベースを低コストの開始パートナーとして使用できます。
2.MySQLでユーザーを追加する
個人的なレッスンですが、Mysql アカウントを追加するときは、ユーザー名とホスト (ローカルと %) を必ず引用符で囲んでください。そうしないと、コマンドが間違ってしまいます。
コマンド モード。各行の後にコマンド ステートメントの終わりを示す ; が続くことに注意してください。
形式: 「パスワード」で識別される「ユーザー名」@「ログインホスト」にデータベース.* で選択を許可します。
例 1. ユーザー test1 をパスワード abc で追加します。これにより、彼は任意のホストにログインし、すべてのデータベースに対するクエリ、挿入、変更、および削除の権限を得ることができます。まず root ユーザーとして MYSQL に接続し、次のコマンドを入力します。
*.* の select、insert、update、delete を「test1」@「%」に許可します。「abc」で識別されます。
すべての許可ステートメントを追加します。
例 1 より: 実行権限 (選択、挿入など) をすべての権限に変更します。これは、データベース権限の作成やデータベースの削除を含むすべての権限を持っていることを意味します。操作は 1 つのデータベース内に限定されなくなります。
*.* のすべての権限を '123456' で識別される 'root'@'%' に付与します。
例 1 (非補足) で追加されたユーザーは非常に危険です。ホストは % であり、% は任意の場所のホストを表し、local は「ローカル」を意味します。誰かが test1 のパスワードを知りたい場合、彼はそれを行うことができます。インターネット上の任意のコンピュータから MySQL データベースに接続し、データに対して必要な操作を実行します。解決策については例 2 を参照してください。
例 1 の補足ステートメントに従って、サーバーが管理対象ゾーンまたはリモート ゾーンにある場合、MySQL サーバーをリモートで管理する必要があり、MySQL サーバーにログインしたくない場合は、このステートメントを MySQL サーバーで使用しないようにしてください。ハイパー ターミナル経由でサーバーに接続する場合は、このステートメントを使用する必要があります。ただし、1 つ注意してください。それは、この方法を使用してサーバーに接続することができ、他の方法でも同様に接続できるため、mysql パスワードを安全に保管してください。
例 2: ユーザー test2 をパスワード abc で追加します。これにより、ユーザーは localhost にのみログインでき、データベース mydb のクエリ、挿入、変更、削除ができるようになります (localhost はローカル ホスト、つまり、 MYSQL データベースは存在します))。そのため、ユーザーが test2 のパスワードを知っていたとしても、インターネットからデータベースに直接アクセスすることはできず、MYSQL ホスト上の Web ページを介してのみアクセスできます。
mydb.* の select、insert、update、delete を「abc」で識別される「test2」@localhost に許可します。
test2 にパスワードを設定したくない場合は、別のコマンドを入力してパスワードを削除できます。
mydb.* の select、insert、update、delete を "" で識別される "test2"@localhost に許可します。
dez.* での select、insert、update、delete を、「123456」で識別される「test2」@「%」に許可します。
上記では、php がなければ私の人生は最悪だと紹介しました。データベースとして mysql を選択する理由は何ですか? Mysql はユーザー メソッドを作成します。これが、PHP チュートリアルに興味のある友人にとって役立つことを願っています。