質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

1回答

517閲覧

MySQLのユーザーに権限を与えられない

kuu13580

総合スコア11

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2023/04/09 18:27

現状

WindwosのWSL2上でWEBアプリの開発をしようと考えている初学者です。
MySQL5.7をインストールしてDBの構築をしようとしたところ、
ルートログイン、データベースの作成はうまくいったのですが、作成したユーザーに対してデータベースへの権限を与えるところでエラーが出ました。
以下それまでに打ったコマンドとエラーです。

$ mysql -u root mysql> CREATE DATABASE test; Query OK, 1 row affected (0.01 sec) mysql> CREATE USER 'test'@'localhost' IDENTIFIED BY '****'; Query OK, 0 rows affected (0.00 sec) mysql> GRANT SELECT, DELETE, UPDATE, INSERT ON test.* TO 'test'@'localhost'; ERROR 1044 (42000): Access denied for user 'root'@'localhost' to database 'test'

書いている通り権限が与えられていないのかと考えて確認すると、

mysql> SELECT user(); +----------------+ | user() | +----------------+ | root@localhost | +----------------+ mysql> SHOW GRANTS; +--------------------------------------------------------------+ | Grants for root@localhost | +--------------------------------------------------------------+ | GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' | | GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION | +--------------------------------------------------------------+ 2 rows in set (0.00 sec)

rootユーザーにはGRANTの権利があると認識しているのですが、
なぜAccess Deniedになるのかわからなくて困っています。
原因になりそうなことをご教示いただけますと幸いです。

環境の情報など

  • OS

Ubuntu 20.04 LTS on WSL2

  • MySQL

Ver.5.7.41

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

rootユーザーにはGRANTの権利があると認識しているのですが、
GRANT ALL PRIVILEGES ON . TO 'root'@'localhost'

GRANT権限が無いように思います。
下記のようになっている必要があります。

SQL

1GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION

下記でrootにGRANT権限を与えてみてください。

SQL

1update mysql.user set Grant_priv='Y' where user='root';

反映

SQL

1FLUSH PRIVILEGES;

投稿2023/04/09 19:38

pippi19

総合スコア679

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kuu13580

2023/04/09 20:56

解決できました!ありがとうございます。 GRNAT権限はALLに含まれないんですね...
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問