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

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

ただいまの
回答率

89.07%

JavaからのMySQLへのDB接続

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,204

YutaNkai

score -61

JavaからMySQLへの接続でエラーが出ております。
接続しようとしているdb: college
ユーザー名:tennisuser
パスワード:password

これで間違いはありません。PHPでは以下の要領で接続ができております。

$dsn = 'mysql:host=localhost:8889;dbname=SNS;charest=utf8';
$user = 'tennisuser';
$password = 'password';

function connectdb()
{
    global $dsn,$user,$password;/*関数外で宣言された関数*/

    try {
        $db = new PDO($dsn, $user, $password);
        $db ->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $db ->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
    } catch (PDOException $e) {
        $db = $e ->getMessage();
    }
    return $db;
}

これが問題のJavaです。どこが問題でしょうか。

package section316;

//データベースへ接続するクラス
import java.sql.Connection;
import java.sql.DriverManager;


public class ConnectDB {

    public static void main(String[] args) throws Exception {

        // データベース接続に使うクラスをロードする
        Class.forName("com.mysql.jdbc.Driver");

        // データベースに接続する
        Connection con = DriverManager.getConnection("jdbc:mysql://localhost:8889/college","tennisuser", "password");

        System.out.println(
                "データベースの接続状態:" + con.isClosed());

        // データベースとの接続を閉じる
        con.close();

        System.out.println(
                "データベースの接続状態:" + con.isClosed());
    }
}


以下エラーメッセージです。

Exception in thread "main" java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at section316.ConnectDB.main(ConnectDB.java:12)

一応DBの構造をあげておきます。
イメージ説明

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2019/01/04 21:28 編集

    「エラーメッセージの通りです」のみの回答で構いませんか?
    あなたの質問は注意力不足か探せばすぐ解決方法がたくさん出てくる内容ばかりです。その自覚がない限りまともな回答は得られませんし、何も進みませんよ。

    キャンセル

回答 2

checkベストアンサー

0

お使いのMySQLのバージョンにあわせたJDBCドライバを、実行環境のクラスパスに追加してください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/01/04 21:52

    mysql-connector-java-8.0.13.tar

    をダウンロードし、TomCatのアパッチの中のbinに置きましたが、依然エラーが消えません。
    ドライバのダウンロード先はここです。
    https://dev.mysql.com/downloads/file/?id=480291

    ターミナルでmysql --versionを実行しても、
    not found 返ってきます。間違いなくあるはずなんですが。

    キャンセル

  • 2019/01/04 22:01

    Javaから実行する場合はJavaのクラスパスに追加しなければならず、binにおいても意味はなく、tarファイルでもありません。
    なお、MySQL8であればmysql-connector-java-8.0.13.jarでよいですが、MySQLのメジャーバージョンは8でしょうか?回答にも書きましたが、より詳細に書くと、メジャーバージョンは合わせなければいけません。

    キャンセル

  • 2019/01/05 20:25

    ありがとうございます。エクリプス内のビルドパスを追加というところに配置すると上手くいきました。

    キャンセル

0

えるしってるか

JDBC 4.0 で Class.forName("com.mysql.jdbc.Driver"); 周りの記述方法が変わっています。

また 導入してるライブラリのパッケージ構成ぐらい確認しよう。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.07%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る