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

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

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

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

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

Q&A

解決済

1回答

11028閲覧

MySQLでのJDBC接続

shimamo

総合スコア7

MySQL

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

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

0グッド

1クリップ

投稿2020/03/17 12:48

編集2020/03/19 10:57

前提・実現したいこと

MySQLにJDBC接続したい。

Linux環境でMySQLにJDBCドライバを使用して接続しようとするとエラーが発生しました。

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

Details: com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.

試したこと

JDBC接続でなく、mysql -h ホスト名 -P ポート -u ユーザ名 -pパスワード
で実施すると接続できます。
同じホスト名・ポート・ユーザ名・パスワードを使用しているので、違うところはJDBCドライバを使用しているところ
だけなので、JDBCドライバを疑っております。
JDBCドライバに対して何か必要なのでしょうか。もしくは他に何か考えられますでしょうか。
環境変数のCLASSPATHにJDBCドライバのありかを指定しております。

<追記>
ありがとうございます。情報追記します。
MySQLのバージョンは5.6.10
MySQLのJDBCドライバはmysql-connector-java-8.0.19.jarです。
他は以下です。
IBM WebSphere Application Server 8.5.5
IBM MobileFirst Platform Foundation 7.1
IBM JDK 8.0

MobileFirst Platform Foundationのantタスクを使用して
データベース作成する際にエラーになりました。

「mysql "The driver has not received any packets from the server."」
では検索してみているのですが、うまく見つけられませんでした。

https://qiita.com/syoki/items/3d82ef00300868353572にある
8.x以前:「com.mysql.jdbc.Driver」
8.x:「com.mysql.cj.jdbc.Driver」
ですが、ログ上に
「Loading class com.mysql.jdbc.Driver'. This is deprecated. The new driver class is com.mysql.cj.jdbc.Driver'.
The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.」
と出ているので、怪しそうですが「com.mysql.jdbc.Driver」の設定を探しているのですが、どこにあるか見つけられてません。
<追記>
MySQL自体はAuroraなので、そちら側でエラー出ていないか確認しましたがエラーは出てませんでした。
MySQLクライアントとしてmariaDBが入っていたので削除してMySQL Communityを入れてみたのですが、結果変わらずでした。
mysql-community-client-5.6.38-2.el6.x86_64
mysql-community-common-5.6.38-2.el6.x86_64
mysql-community-libs-5.6.38-2.el6.x86_64
<追記>
MySQLのバージョンが5.6の場合MySQLのJDBCドライバは最新の8.0系でなく5.1系でも大丈夫なことが分かったので、
5.1に落としたらうまくいきました。
https://dev.mysql.com/downloads/connector/j/5.1.html
ネットでmysql connector/j ダウンロードと検索すると以下のページが出て8.0しか出てこないのでで何とかする方法を
探してしまいましたが、5.1でもいけないか確認すべきでした。ヒントくださったかたありがとうございました。
https://www.mysql.com/jp/products/connector/

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

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

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

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

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

encho

2020/03/17 13:03

MySQLとeclipseのバージョンを記載した方が回答が集まるかと思います。 versionによって設定が異なることもあるので。
encho

2020/03/17 13:05

あとコードも記載した方がよろしいかと思います!
jimbe

2020/03/17 13:14

「mysql "The driver has not received any packets from the server."」で検索すると、teratail 含めイロイロ出てきますが, 何か試されましたでしょうか.
jimbe

2020/03/18 02:49

> 「com.mysql.jdbc.Driver」の設定を探しているのですが mysql-connector-java-8.0.19.jar に入っているのが com.mysql.jdbc.Driver で, リンク先の方法でダウンロードできる jar に入っているのが com.mysql.cj.jdbc.Driver ということではないでしょうか.
shimamo

2020/03/18 03:00

mysql-connector-java-8.0.19.jar を解凍してファイルjava.sql.Driverの内容を参照したのですが、com.mysql.cj.jdbc.Driverと記載されておりました。MySQLの設定にあるかもと場所を調査中です。
jimbe

2020/03/18 03:32

> com.mysql.cj.jdbc.Driverと記載されておりました なるほど, 失礼しました.
guest

回答1

0

自己解決

mysql connector/j 5.1に落としたらうまくいきました。
mysql-connector-java-5.1.48.jar

投稿2020/03/19 10:58

shimamo

総合スコア7

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問