[Java]DB(MySQL)からデータ取得する方法とは?環境の構築方法・DBからデータを取得する方法・DBにデータを登録する方法
![[Java]DB(MySQL)からデータ取得する方法とは?環境の構築方法・DBからデータを取得する方法・DBにデータを登録する方法](https://www.fenet.jp/java/column/wp-content/uploads/2020/05/626361926.jpg)
- システム
エンジニア - JavaのDB(MySQL)からデータ取得するにはどのようにすれば良いのでしょうか。
- プロジェクト
マネージャー - LinuxのJava環境やDBの環境について説明しますので、一緒に見ていきましょう。
[Java]DB(MySQL)からデータ取得する方法とは?
今回は、JavaでDB(MySQL)からデータ取得する方法について説明します。開発環境はLinuxとします。環境構築方法、DBからデータ取得方法、DBにデータ登録方法について紹介します。
JavaでDB(MySQL)からデータ取得する方法に興味のある方はぜひご覧ください。
Java環境
LinuxのJava環境について説明します。
ディストリビューション:Ubuntu
javac 13.0.1
openjdk 13.0.1 2019-10-15
mysql-connectorを使用可能とするため、以下のコマンドを実行します。Javaのクラスパスを通すのを省略するためにカレントにコピーします。
1 2 3 |
wget http://dev.mysql.com/get/Downloads/Connector-J/mysql-connector-java-5.1.30.tar.gz -O mysql-connector.tar.gz tar -xvzf mysql-connector.tar.gz cp mysql-connector-java-5.1.30/mysql-connector-java-5.1.30-bin.jar mysql-connector.jar |
DB(MySQL)環境
DBの環境について説明します。
DB:MySQL
データベース名:mydb
テーブル情報は以下とします。
1 2 3 4 5 6 7 8 |
mysql> desc user; +-------+---------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | text | YES | | NULL | | | age | int(11) | YES | | NULL | | +-------+---------+------+-----+---------+----------------+ |
テーブルには以下のデータが格納済みとします。
1 2 3 4 5 6 7 8 |
mysql> select * from user; +----+--------+------+ | id | name | age | +----+--------+------+ | 1 | taro | 20 | | 2 | jiro | 25 | | 3 | saburo | 30 | +----+--------+------+ |
以降の章で、Javaでこれらのデータ取得方法を紹介します。
select
JavaでDBからデータ取得する方法を紹介します。実際のソースコードを見てみましょう。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class DbSample { public static void main(String[] args) { String url = "jdbc:mysql://localhost/mydb?useSSL=false"; String user = "root"; String password = ""; Connection con = null; PreparedStatement pstmt = null; ResultSet rs = null; String sql = "select * from user"; try { // 接続 con = DriverManager.getConnection(url, user, password); // パラメータ付きSQL文をDBに送るためのオブジェクト生成 pstmt = con.prepareStatement(sql); // SQL文の実行(データ取得) rs = pstmt.executeQuery(); // データ取得したレコードの表示 while (rs.next()) { System.out.println(rs.getString("name")); System.out.println(rs.getInt("age")); } } catch (SQLException e) { e.printStackTrace(); } finally { try { if (rs != null) { rs.close(); } } catch (SQLException e) { e.printStackTrace(); } try { if (pstmt != null) { pstmt.close(); } } catch (SQLException e) { e.printStackTrace(); } try { if (con != null) { con.close(); } } catch (SQLException e) { e.printStackTrace(); } } } } |
以下のようにコンパイルして実行します。
1 2 |
~$ javac -classpath mysql-connector.jar DbSample.java ~$ java -classpath mysql-connector.jar: DbSample |
実行結果は以下のようになります。JavaでDBからデータ取得されていることが分かります。
1 2 3 4 5 6 |
taro 20 jiro 25 saburo 30 |
insert
JavaでDBにデータ登録する方法を紹介します。実際のソースコードを見てみましょう。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class DbSample { public static void main(String[] args) { String url = "jdbc:mysql://localhost/mydb?useSSL=false"; String user = "root"; String password = ""; Connection con = null; PreparedStatement pstmt = null; ResultSet rs = null; String sql = "insert into user (name, age) VALUES (?,?)"; try { // 接続 con = DriverManager.getConnection(url, user, password); // パラメータ付きSQL文をDBに送るためのオブジェクト生成 pstmt = con.prepareStatement(sql); pstmt.setString(1,"shiro"); pstmt.setString(2,"35"); // SQL文の実行 pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { System.out.println("done."); } } } |
実行後にMySQLでselectすると、以下の結果となります。
1 2 3 4 5 6 7 8 9 |
mysql> select * from user; +----+--------+------+ | id | name | age | +----+--------+------+ | 1 | taro | 20 | | 2 | jiro | 25 | | 3 | saburo | 30 | | 4 | shiro | 35 | +----+--------+------+ |
- システム
エンジニア - 環境構築方法やDBにデータ登録方法などについて理解できました。
- プロジェクト
マネージャー - JavaでDB(MySQL)からデータ取得する方法をより理解するために、ソースコードで指定してみましょう。
まとめ
いかがでしたでしょうか。JavaでDB(MySQL)からデータ取得する方法について説明しました。開発環境はLinuxです。環境構築方法、DBからデータ取得方法、DBにデータ登録方法について紹介しました。
ぜひご自身でJavaのソースコードを書いて、理解を深めてください。
FEnetJava・Javaコラムは株式会社オープンアップシステムが運営しています。
株式会社オープンアップシステムはこんな会社です
秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
スマホアプリから業務系システムまで
スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。
-
充実した研修制度
毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。
-
資格取得を応援
スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。
-
東証プライム上場企業グループ
オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
株式会社オープンアップシステムに興味を持った方へ
株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。


Java新着案件New Job
官公庁向け業務システム開発/Java/東京都千代田区/【WEB面談可】/テレワーク
月給39万~44万円東京都千代田区(永田町駅)販売管理システム開発/Java/東京都中央区/【WEB面談可】/テレワーク
月給49万~55万円東京都中央区(京橋駅)生命保険会社向けシステム開発/Java/東京都千代田区/【WEB面談可】/テレワーク
月給42万~48万円東京都千代田区(大手町駅)社会保険システムのパッケージ開発/Java/東京都港区/【WEB面談可】/テレワーク
月給42万~48万円東京都港区(新橋駅)金融機関向けシステム更改/Java/東京都江東区/【WEB面談可】/テレワーク
月給46万~51万円東京都江東区(豊洲駅)大手通信会社者向けWebシステム改修/Java/東京都港区/【WEB面談可】/テレワーク
月給42万~48万円東京都港区(品川駅)