JDBC (Java Database Connectivity) は、MySQLやPostgreSQLといった数々のSQLデータベース、あるいはスプレッドシートなどのデータファイルにJavaからアクセスするためのAPIです。アクセス先ごとに専用のドライバが提供されているため、事前にインストールしておく必要があります。ここではMySQLへの接続を例に取り、基本的なサンプルプログラムを紹介します。
まず、MySQLのダウンロードページにアクセスします。そのページ内にある、"MySQL Connectors" というリンクをクリックすると、MySQLのドライバ一覧が表示されます。ここではJavaのJDBCドライバが必要ですので、"Connector/J" をクリックします。表示されたダウンロードページのプルダウンから "Platform Independent" を選択し、zipまたはtarのいずれかをダウンロードおよび解凍してください。
解凍したフォルダを適当な場所、例えば "C:\Program Files\Java" 内に移動させ、環境変数CLASSPATHにjarファイル "mysql-connector-java-5.1.31-bin.jar" (ダウンロードしたバージョンによってファイル名は若干異なります) へのパス (例: "C:\Program Files\Java\mysql-connector-java-5.1.31\mysql-connector-java-5.1.31-bin.jar") をセミコロン区切りで追加することで、インストールが完了します。
jdbc_sample.java
import java.sql.*;
class JdbcSample {
public static void main (String[] args) {
try {
// 先程インストールしたMySQLのドライバを指定
Class.forName("com.mysql.jdbc.Driver");
// MySQLデータベースに接続 (DB名,ID,パスワードを指定)
Connection conn =
DriverManager.getConnection("jdbc:mysql://localhost/YOUR_DBNAME?"+
"user=USER_ID&password=PASSWORD");
// ステートメントを作成
Statement stmt = conn.createStatement();
// INSERT
stmt.executeUpdate("INSERT INTO users (id, email) VALUES (1001,'someone01@example.com')");
stmt.executeUpdate("INSERT INTO users (id, email) VALUES (1002,'someone02@example.com')");
// DELETE
stmt.executeUpdate("DELETE FROM users where id=1001");
// UPDATE
stmt.executeUpdate("UPDATE users SET email='updated@example.com' where id=1002");
// SELECT
ResultSet rset = stmt.executeQuery("SELECT id, email FROM users");
while ( rset.next() ) {
System.out.println(rset.getInt(1) + "\t" + rset.getString(2)); // ()内は列番号です
}
// 結果セットをクローズ
rset.close();
// ステートメントをクローズ
stmt.close();
// 接続をクローズ
conn.close();
}
catch (Exception e) {
e.printStackTrace();
}
}
}
$ javac -encoding utf-8 jdbc_sample.java && java JdbcSample
1002 updated@example.com
(javaソースファイルがutf-8で保存されている場合でかつ環境設定がutf-8でない場合は、"-encoding utf-8" でエンコーディングを明記する必要があります)