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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

データベース

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

Q&A

2回答

28475閲覧

DB接続クラスのエラーについて

Kyouko_kisaragi

総合スコア48

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

データベース

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

1グッド

2クリップ

投稿2016/09/11 11:14

編集2016/09/11 13:48

データベースに接続する際、エラーが出てしまいます。
以下の内容です。

SQLException:Access denied for user 'root'@'localhost' (using password: YES) コネクションがありません

また、コマンドの方でも確かめました。
きちんと接続できています。

イメージ説明

文面からするに、パスワードは合っているのだと思います。
ただ、ユーザー名で何かあったという感じだと考えています。
しかし、最初にコマンドの方でデータベースに接続した時はきちんと入れました。パスワードも間違っていないようです。

以下、接続する際に使用したURLです。
mysqlを使用し、db名は"kadaidb"です。

jdbc:mysql://localhost/kadaidb

きちんと接続するにはどうすればいいのでしょうか。
よろしくお願いします。

Konakona_👍を押しています

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

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

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

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

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

KiyoshiMotoki

2016/09/11 13:28

「コマンドの方でデータベースに接続した時はきちんと入れました」とのことですが、その際に実行したコマンドを質問欄に記載してください。そうすれば、より詳しい状況が分かるかもしれません。
guest

回答2

0

root@127.0.0.1に対して権限を与えればログインできると思います。

GRANT ALL PRIVILEGES ON kadaidb.* TO root@127.0.0.1;

コマンドとJDBCで接続方式が違うので認証エラーになっています。
mysql -u root -p はソケット接続でJDBCはTCP/IP接続なので認証ホストの扱いが異なります。
以下のコマンドで接続できるように設定すればJDBCでもうまくいきますよ。

mysql -u root -h 127.0.0.1 -p kadaidb

http://qiita.com/TanukiTam/items/f6a08740d0fcda0db7be
http://b.l0g.jp/mysql/user-at-localhost/

投稿2016/09/11 14:08

kodai

総合スコア759

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

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

Kyouko_kisaragi

2016/09/11 14:29

アドバイスありがとうございます。 早速やってみたところ、このようなコマンドになりました。 >mysql -u root -h 127.0.0.1 -p kadaidb Enter password: ***************** Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 21 Server version: 5.7.11-log MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. アドバイスをいただいたコマンドで接続できるようです。 ということは、既に権限はあるということになるのでしょうか。 ちなみに、このコマンドの後にGRANT ALL~を入力したところ、エラーになりました。
KiyoshiMotoki

2016/09/11 15:41

kodai様、Kyouko_kisaragi様 横から失礼します。 Kyouko_kisaragi様 Javaコードの変数 url を以下のように変更し、再度、実行してみてください。  String url = "jdbc:mysql://127.0.0.1:3306/kadaidb"; $ mysql -u root -p のときと >mysql -u root -h 127.0.0.1 -p kadaidb のときとで使用するパスワードが異なる場合、変数 password も" -h 127.0.0.1"のものに変更してください。
guest

0

エラーメッセージで検索してみたならパスワードが誤っているとの情報がヒットすると思うのですが・・・。
以下のコマンドを実行してDBに接続できるか確認してみてください。

sh

1$ mysql -u root -p 2Enter password:

パスワードが合わない場合は以下のメッセージが表示されます。

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

投稿2016/09/11 11:21

編集2016/09/11 11:25
tkmtmkt

総合スコア1800

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

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

Kyouko_kisaragi

2016/09/11 11:27

コメントありがとうございます。 コマンドプロンプトで確認したところ、きちんと接続できました。
tkmtmkt

2016/09/11 11:36

エラー発生個所周辺(データベース接続回り)のソースコードを添付できますか?
Kyouko_kisaragi

2016/09/11 12:57

遅くなり申し訳ございません。 以下になります。 public class Test extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { res.setContentType("text/html; charset=Shift_JIS"); PrintWriter out = res.getWriter(); out.println("<html>"); out.println("<head>"); out.println("<title>データベーステスト</title>"); out.println("</head>"); out.println("<body>"); out.println("<p>"); Connection conn = null; String url = "jdbc:mysql://localhost:3306/kadaidb"; String user = "root"; String password = "○○○○○○○○"; try { Class.forName("com.mysql.jdbc.Driver").newInstance(); out.println("ドライバのロードに成功しました<br>"); conn = DriverManager.getConnection(url, user, password); out.println("データベース接続に成功しました<br>"); }catch (ClassNotFoundException e){ out.println("ClassNotFoundException:" + e.getMessage()); }catch (SQLException e){ out.println("SQLException:" + e.getMessage()); }catch (Exception e){ out.println("Exception:" + e.getMessage()); }finally{ try{ if (conn != null){ conn.close(); out.println("データベース切断に成功しました"); }else{ out.println("コネクションがありません"); } }catch (SQLException e){ out.println("SQLException:" + e.getMessage()); } } out.println("</p>"); out.println("</body>"); out.println("</html>"); } // デバッグしたところ、『 conn = DriverManager.getConnection(url, user, password);』でエラーが出ています。
tkmtmkt

2016/09/12 14:38

ソースコードは質問のほうに追記したほうが良いです。みづらいので。 サンプルコード作成して実行してみたら問題なく接続できました。パスワードに「¥」が含まれていたりしますか?
Kyouko_kisaragi

2016/09/12 14:44

コメントありがとうございます。 パスワードに含まれているのは『_』です。\は含まれていません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問