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

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

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

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

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

Q&A

解決済

2回答

531閲覧

XAMPPphpMyAdmin,MySQLにPHP側から接続したいです(XAMPPを利用しています)

resta2019

総合スコア11

MySQL

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

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

0グッド

0クリップ

投稿2019/09/16 06:14

編集2019/09/16 08:04

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。

PHP側からMySQLに接続する際に以下のエラーメッセージが発生しました。
※MySQL側からの操作では問題なく動きます。

よろしくお願いいたします。

※追記
データベース「booksample」は作成済みですが、testuserはまだ作成されていない状態です。
↓のコードを実施することで、testuserが作成されるようになるのか、それともSQL側の操作で先に作成しておくべきかも分かっていない状態です。

発生している問題・エラーメッセージ

接続失敗… エラー内容:SQLSTATE[HY000] [1044] Access denied for user 'testuser'@'localhost' to database 'booksample'

該当のソースコード

PHP ソースコード <meta charset="UTF-8"> <?php #データベースに接続 $dsn = 'mysql:host=localhost; dbname=booksample; charset=utf8'; $user = 'testuser'; $pass = 'testpass'; try{ $dbh = new PDO($dsn, $user, $pass); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); if ($dbh == null){ # DB接続に失敗したときここは実行されず、catch内が実行される }else{ echo "接続成功!"; } }catch (PDOException $e){ echo "接続失敗…<br>"; echo "エラー内容:".$e->getMessage(); die(); } $dbh = null;

試したこと

ここに問題に対して試したことを記載してください。
コードの見直し。
コードが記載されているテキストと相違がないかの確認。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。
terapadでhtdocsのフォルダ内で動かしています。
イメージ説明
イメージ説明
イメージ説明

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2019/09/16 06:21

ユーザーtestuserはlocalhost上のデータベースbooksampleに存在するのかい?
resta2019

2019/09/16 06:23

ありがとうございます。 はい、 $dsn = 'mysql:host=localhost; dbname=booksample; charset=utf8'; ↓ $dsn ='mysql:host=localhost;dbname=booksample;charset=utf8'; にしてみましたが、同じメッセージが表示され、接続できない状態です。
退会済みユーザー

退会済みユーザー

2019/09/16 06:28

なにかの本を参考にしているのであれば、どういう本の何ページの記述を見ながらとか、なにかのweb記事を参考にしているのであればそのurlとか、第三者が参考資料を理解できる助けになるよう情報を質問文中に加筆してほしい。
退会済みユーザー

退会済みユーザー

2019/09/16 06:49

XAMPP Control PanelでApacheやMySQLの稼働状況がわかるスクショは掲載できますか?
resta2019

2019/09/16 06:53

>m6uさん 掲載しました。 今回、プログラミングスクールのテキストの内容のコードをそのまま使っています。 分かりづらくてすみません。 よろしくお願いいたします。
guest

回答2

0

ベストアンサー

Access denied for user 'testuser'@'localhost' to database 'booksample'

このエラーメッセージ自体は、MySQLが出しているエラーメッセージなので、

現状把握としては

  • MySQLが存在していない、または起動していないよいう可能性はない。
  • 'testuser'@'localhost' ということから見て、ソースコード上の記述はMySQLには認識されている。
  • to database 'booksample' と書かれているので、データベースの指定もできている。dsn 文字列の空白があっても今回の場合は無関係

残された可能性は、 ユーザー名かパスワード、または両方が間違っている


データベース「booksample」は作成済みですが、testuserはまだ作成されていない状態です。

↓のコードを実施することで、testuserが作成されるようになるのか、それともSQL側の操作で先に作成しておくべきかも分かっていない状態です。

MySQLに前もってユーザーとパスワードは設定する必要があります。

投稿2019/09/16 06:40

編集2019/09/16 07:06
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

resta2019

2019/09/16 08:01

ありがとうございます! 前もってユーザーとパスワードを設定するとのことですね。 トライしてみます。
resta2019

2019/09/16 08:57

testuser@localhost の 編集 をクリックして、GRANT をチェックして実行したところ、解決しました! この度はありがとうございました。
guest

0

あてずっぽうでの回答になるので、間違っていたら消すかもしれないけども。

なにかの書籍や記事を参考にしてやっているのだろうと察して、
その場面に差し掛かるよりも前に、
準備段階として、
mysql上にデータベースbooksampleを作成してユーザーtestuserでアクセスできるようにするための
手順が絶対どこかにあるはずなので、
まずその内容を確認してほしい。
一言一句写経したとして、エラーメッセーなど出ていなかったか。など。

XAMPPの稼働状況は、XAMPP Control Panel上から確認できる。
mysqlが動作しているか、動作していれば緑の表示がある。
またPort(s)のところにmysqlがlistenするポート番号が書いてあるので、
3306と違う数字であればphpのコードも直さないと絶対つながらないし。


phpMyAdminってXAMPPには含まれていないはずで、
それをどう構築したか、
ファイルを置くだけじゃダメで、
phpMyAdminからデータベースにアクセスするための定義ファイルも
なにかしら書き換えて動かしているはずだけど。
(わたしはPostgreSQLの方なら少しわかるけどmysqlはよくわからん。)

投稿2019/09/16 06:32

編集2019/09/16 06:34
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

resta2019

2019/09/16 08:03

回答ありがとうございます! XAMPPコントロールパネル上での表示は緑になっています。port(s)も3306です。 ユーザアカウントのタブにて、 「localhostから任意のユーザーに接続を許可するユーザが存在します。 これにより、そのアカウントのホスト部分で任意ホスト(%)からの接続が許可されている場合、他のユーザーは接続できなくなります。」と表示されているため、これが原因なのかと思ったのですがよくわかっていない状態です
resta2019

2019/09/16 08:57

testuser@localhost の 編集 をクリックして、GRANT をチェックして実行したところ、解決しました! この度はありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問