🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JDBC

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

Java

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

IntelliJ IDEA

IntelliJ IDEA(インテリジェイ アイディア)は、JetBrains社が開発した、 JavaやScalaなどで利用される統合開発環境です。

Q&A

解決済

1回答

1216閲覧

JavaでのMySQL接続

takumi_6084

総合スコア6

JDBC

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

Java

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

IntelliJ IDEA

IntelliJ IDEA(インテリジェイ アイディア)は、JetBrains社が開発した、 JavaやScalaなどで利用される統合開発環境です。

0グッド

0クリップ

投稿2020/12/29 07:38

  • JDK 1.8
  • MySQL-Connector-java-8.0.22.jar

↑外部ライブラリに入れたもの

Java

1public class Test { 2 public static void main(String[] args) { 3 final String PATH = "test/"; 4 File file = new File(PATH); 5 if (!file.exists()) { 6 file.mkdirs(); 7 File database = new File(PATH + "test.db"); 8 try { 9 database.createNewFile(); 10 System.out.println(database.exists()); 11 SQL sql = new SQL(PATH + "test.db"); 12 sql.createTable("test", "test TEXT"); 13 } catch (IOException e) { 14 e.printStackTrace(); 15 } 16 } 17 } 18}

Java

1public SQL(String database_name) { 2 this.DATABASE_NAME = database_name; 3 } 4 5 public void createTable(String table_name, String column) { 6 Connection connection = null; 7 Statement statement = null; 8 try { 9 Class.forName("com.mysql.cj.jdbc.Driver"); 10 connection = DriverManager.getConnection("jdbc:mysql:" + this.DATABASE_NAME); 11 statement = connection.createStatement(); 12 statement.executeUpdate("CREATE TABLE IF NOT EXISTS " + table_name + " (" + column + ")"); 13 } catch (SQLException | ClassNotFoundException throwables) { 14 throwables.printStackTrace(); 15 } finally { 16 try { 17 if (statement != null) { 18 statement.close(); 19 } 20 if (connection != null) { 21 connection.close(); 22 } 23 } catch (SQLException e) { 24 e.printStackTrace(); 25 } 26 } 27 } 28}

これを実行すると

No suitable driver found for jdbc:mysql:test/test.db at java.sql.DriverManager.getConnection(DriverManager.java:689) at java.sql.DriverManager.getConnection(DriverManager.java:270) at main.SQL.createTable(SQL.java:19) at main.Test.main(Test.java:19)

となってしまいます。

IntelliJの外部ライブラリに上のjarは入れてありますが、できなかったため、pom.xmlに

<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.22</version> </dependency>

これを記載して外部ライブラリのほうは抜いて、実行してもエラーがでました。

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

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

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

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

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

guest

回答1

0

自己解決

pom.xmlを↓にして、

<dependency> <groupId>org.xerial</groupId> <artifactId>sqlite-jdbc</artifactId> <version>3.34.0</version> </dependency>

java

1Class.forName("org.sqlite.JDBC"); 2connection = DriverManager.getConnection("jdbc:sqlite:" + this.DATABASE_NAME);

こう変えたらできるようになった

投稿2020/12/29 07:51

takumi_6084

総合スコア6

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問