ホームページ  >  記事  >  データベース  >  mysql に追加したユーザーにアクセスできない場合はどうすればよいですか?

mysql に追加したユーザーにアクセスできない場合はどうすればよいですか?

coldplay.xixi
coldplay.xixiオリジナル
2020-10-20 11:19:102284ブラウズ

mysql に追加されたユーザーがアクセスできない問題の解決策: まず管理者として MySQL サーバーにログインし、MySQL ユーザーを作成します。次に、MySQL ユーザーに権限を付与し、次のコマンドを実行して " myuser" ユーザー固有の権限; 最後に、ユーザーのリソース制限を追加して確認します。

mysql に追加したユーザーにアクセスできない場合はどうすればよいですか?

その他の関連する無料学習の推奨事項: mysql チュートリアル#(ビデオ)

Mysql に追加されたユーザーがソリューションにアクセスできません:

まず、中間管理者として MySQL サーバーにログインします。

$ mysql -u root -p

作成されたユーザーを表示します

SELECT host, user FROM mysql.user;

MySQL ユーザーの作成

  创建一个用户名和密码分别为"myuser"和"mypassword"的用户,可访问地址为%所有,也可以设定ip或者localhost。
  mysql> CREATE USER 'myuser'@'%' IDENTIFIED BY 'mypassword';
  用户被创建后,包括加密的密码、权限和资源限制在内的所有帐号细节都会被存储在mysql这个库的user的表中。
 ** 运行下列命令,验证帐号是否创建成功**
  mysql> SELECT host, user, password FROM mysql.user WHERE user='myuser';

MySQL ユーザー権限の付与

新しく作成された MySQL ユーザーにはアクセス権限がありません, したがって、MySQL データベースでは操作を実行できないことを意味します。ユーザーに必要な権限を与える必要があります。使用可能な権限の一部を以下に示します。

#ALL: 使用可能なすべての権限
  • #CREATE: ライブラリ、テーブル、インデックスの作成

  • LOCK_TABLES: テーブルをロック

  • #ALTER: テーブルを変更

  • ##DELETE: テーブルを削除
  • #INSERT: テーブルまたは列に挿入
  • #SELECT: テーブルまたは列からデータを取得
  • ##CREATE_VIEW: ビューを作成

  • SHOW_DATABASES: データベースのリスト

  • DROP: ライブラリ、テーブル、ビューの削除

  • #Run 次のコマンドは、「myuser」ユーザーに特定の権限を与えます。
  • mysql> GRANT <privileges> ON <database>.<table> TO &#39;myuser&#39;@&#39;localhost&#39;;
      以上命令中,<privileges> 代表着用逗号分隔的权限列表。如果你想要将权限赋予任意数据库(或表),那么使用星号(*)来代替数据库(或表)的名字。
      例如,为所有数据库/表赋予 CREATE 和 INSERT 权限:
      mysql> GRANT CREATE, INSERT ON *.* TO &#39;myuser&#39;@&#39;localhost&#39;;

    ユーザーに付与されている完全な権限を確認します:
mysql> SHOW GRANTS FOR &#39;myuser&#39;@&#39;localhost&#39;;
  **将全部的权限赋予所有数据库/表:**
  mysql> GRANT ALL ON *.* TO &#39;myuser&#39;@&#39;localhost&#39;;
  **你也可以将用户现有的权限删除。使用以下命令废除"myuser"帐号的现有权限:**
  mysql> REVOKE <privileges> ON <database>.<table> FROM &#39;myuser&#39;@&#39;localhost&#39;;

ユーザーのリソース制限を追加します

MySQL では、個々のユーザーに対して MySQL リソースの使用制限を設定できます。利用可能なリソース制限は次のとおりです。

MAX_QUERIES_PER_HOUR: 允许的每小时最大请求数量
  MAX_UPDATES_PER_HOUR: 允许的每小时最大更新数量
  MAX_CONNECTIONS_PER_HOUR: 允许的每小时最大连接(LCTT译注:其与 MySQL全局变量: max_user_connections 共同决定用户到数据库的同时连接数量)数量
  MAX_USER_CONNECTIONS: 对服务器的同时连接量

次のコマンドを使用して、「myuser」アカウントにリソース制限を追加します。

mysql> GRANT USAGE ON <database>.<table> TO &#39;myuser&#39;@&#39;localhost&#39; WITH <resource-limits>;
  在 <resource-limits> 中你可以指定多个使用空格分隔开的资源限制。
  例如,增加 MAXQUERIESPERHOUR 和 MAXCONNECTIONSPERHOUR 资源限制:
  mysql> GRANT USAGE ON *.* TO &#39;myuser&#39;@&#39;localhost&#39; WITH MAX_QUERIES_PER_HOUR 30 MAX_CONNECTIONS_PER_HOUR 6;

ユーザーのリソース制限を確認します。リソース制限:

  mysql> SHOW GRANTS FOR &#39;myuser&#39;@&#39;localhost;

MySQL ユーザーの作成と設定における最後の重要な手順:

  mysql> FLUSH PRIVILEGES;

これで、変更が有効になります。これで、MySQL ユーザー アカウントを使用できるようになりました。

以上がmysql に追加したユーザーにアクセスできない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。