Loading [MathJax]/extensions/tex2jax.js

Rainbow Engine

IT技術を分かりやすく簡潔にまとめることによる学習の効率化、また日常の気付きを記録に残すことを目指します。

Java OracleDB

APサーバ(Java)⇒DBサーバ(OracleDB 11g)へJDBC接続する方法まとめ

投稿日:2018年8月26日 更新日:

(0)目次

(1) 前提条件
(2) JDBCドライバーのインストール
 (2-1) JDBCドライバーをダウンロード
 (2-2) APサーバにアップロード・解凍
(3) プログラムの実装
 (3-1) 新規プロジェクトの作成
 (3-2) Class作成 (DB接続用)
 (3-3) Class作成 (Mainメソッド)
(4) DB側のファイアウォール設定 (iptables)
(5) 疎通確認 (Javaアプリケーションの実行)

(1)前提条件

(1-1) AP側

・Javaの開発環境が構築されていること。

(1-2) DB側

・OracleDBのインストールが完了している事
・接続スキーマ作成とデータ登録が完了してる事
目次にもどる

(2) JDBCドライバーのインストール

(2-1) JDBCドライバーをダウンロード

私はOracleDBの11gを使用しているため、該当するバーションを選択します。
http://www.oracle.com/technetwork/jp/database/features/jdbc/index-099275-ja.html

a.「ojdbc-full.tar.gz」を選択します。

b.Oracleのサイトにサインインします。

(2-2) JDBCドライバーをダウンロード

a.ダウンロードしたドライバ「ojdbc-full.tar.gz」をサーバ上の任意のパスにアップロードする

SSH SCP機能を使って転送します。
メニューから「ファイル(F)」⇒「SSH SCP」を選択します。
今回の私の例では、サーバ上の「/usr/local/src/」にアップロードしています。

b.アップロードが完了したら、以下のコマンドでファイルを解凍する
  1. tar xfvz ojdbc-full.tar.gz

目次にもどる

(3)  プログラムの実装

(3-1)  新規プロジェクトの作成

a. メニューから「File」⇒「New」⇒「Project」の順番で選択する。

b.「Java Project」を選択して「Next」を押下
c.「Project Name」に任意の名前を入力し、「Add project to working sets」にチェックをして「Next」を押下する。

d. 「Libraries」のメニューを選択する

e. 選択肢から「Add External JARs」を選択する。

f. アップロードしたjdbcドライバ(ojdbc6.jar)がある階層まで移動し、「ojdbc6.jar」を選択する。

g. 完了したら「finish」を押下する。

h. プロジェクトが追加された事を確認する。


目次にもどる

(3-2)  Class作成 (DB接続用)

a. 「src」を右クリック⇒「New」⇒「Class」の順番で押下する。
b. 「Package」に任意のパッケージ名を入力し、「Name」にJavaファイルの名前を入力したら「Finish」を押下する。

c. 空のJavaファイルが作成された事を確認する。
d. コーディングを行う。

今回は下記のコードをコピーし利用します(丸数字の箇所は各人の情報で置き換えてください)。内容はDBへの接続・切断を行うメソッドです。完了したら「Ctrl+S」などで保存します。

  1. public class JDBCmanager {
  2. // DB Connection Info/DB接続情報
  3. // ① = "HostName"or"IP Address"/「ホスト名」または「IPアドレス」 
  4. // ② = "Port Numer"/「ポート番号」
  5. // ③ = "Net Service Name"/「ネットサービス名」
  6. // ④ = "Schema Name"/「スキーマ名」
  7. // ⑤ = "Password of Schema"/「スキーマのパスワード」
  8. private final String jdbc_url = "jdbc:oracle:thin:@[①]:[②]:[③]";
  9. private final String username = "④";
  10. private final String password = "⑤";
  11. /* Connect to Database */
  12. public Connection getConn() throws ClassNotFoundException, SQLException {
  13. Class.forName("oracle.jdbc.driver.OracleDriver");
  14. Connection conn = DriverManager.getConnection(jdbc_url, username, password);
  15. System.out.println("Database connection success/DBへの接続が完了しました");
  16. return conn;
  17. }
  18. /* End Database Connection */
  19. public void close(Connection conn) {
  20. try {
  21. if(conn != null) {
  22. conn.close();
  23. System.out.println("Database connection Ended/DBへの接続を終了しました");
  24. }
  25. } catch (SQLException e) {
  26. e.printStackTrace();
  27. }
  28. }
  29. }


目次にもどる

(3-3)  Class作成 (Mainメソッド)

a. 「src」を右クリック⇒「New」⇒「Class」の順番で押下する。
b. 「Package」に任意のパッケージ名を入力し、「Name」にJavaファイルの名前を入力したら「Finish」を押下する。
c. 空のJavaファイルが作成された事を確認する。
d. コーディングを行う。

今回は下記のコードをコピーし利用します。内容はDBの「ACCOUNT」テーブルへの照会を行うSQLを発行するメソッドです。完了したら「Ctrl+S」などで保存します。

  1. package application;
  2. public class JDBCoperator {
  3. public static void main(String[] args) {
  4. String select = "SELECT * FROM ACCOUNT";
  5. ResultSet rs = null;
  6. JDBCmanager dbms = new JDBCmanager();
  7. try(Connection conn= dbms.getConn();){
  8. try(Statement stmt = conn.createStatement();){
  9. rs = stmt.executeQuery(select);
  10. while(rs.next()) {
  11. System.out.println("ACCOUNT_ID: "+rs.getInt("ACCOUNT_ID"));
  12. System.out.println(", BALANCE: "+rs.getInt("AVAIL_BALANCE"));
  13. }
  14. }
  15. } catch (ClassNotFoundException e2) {
  16. e2.printStackTrace();
  17. } catch (SQLException e3) {
  18. e3.printStackTrace();
  19. }
  20. }
  21. }

目次にもどる

(4) DB側のファイアウォール設定 (iptables)

a. TeraTermからDBサーバにログインする。
b. rootにスイッチし、「iptables」をVIエディタを使い「編集モード」で開く

c. 行の追加が出来たら「Esc」を押下し、「:wq!」を入力して保存する。

d. iptablesを再起動する


目次にもどる

(5) 疎通確認

a. プロジェクトを右クリックし、「Run As」で「1 Java Application」を選択する

b. 「(3-3)」で作成したMainメソッドを選択する(私の場合「application」パッケージの「JDBCoperator.java」を選ぶ)。

c. 「Console」の窓にSQLの発行結果が表示される。


データベースのテーブルを直接照会した結果と一致しています。

目次にもどる

Adsense審査用広告コード


Adsense審査用広告コード


-Java, OracleDB

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

オープンアドレス法をJavaで実装したプログラムのサンプルをご紹介

<目次> (1) オープンアドレス法をJavaで実装したプログラムのサンプルをご紹介  (1-1) オープンアドレス法とは  (1-2) Javaのサンプルプログラムの全体像  (1-3) Javaの …

Linuxサーバ(CentOS6)にEclipse(OXYGEN)をインストールする

0.目次 (1) JDKの概要  (1-1) JDKの種類  (1-2) JDKのバージョン(2018年2月時点) (2) JDKのインストール  (2-1) wget コマンドでJDK の rpm …

int型のオーバーフロー(桁あふれ)とは?実際の発生パターンと併せてご紹介

  <目次> (1) int型のオーバーフロー(桁あふれ)とは?実際の発生パターンと併せてご紹介  (1-1) int型のオーバーフローとは?  (1-2) int型のオーバーフローが発生す …

Javaのthisとは?コンストラクタで引数を与えている場合・メソッド引数に使われる場合もご紹介

<目次> (1) Javaのthisとは?コンストラクタに出現する場合やメソッド引数に使われる場合もご紹介  (1-1) thisとは?  (1-2) 用途1:自分自身を指定【重要】  (1-3) 用 …

Oracle DBでサンプルスキーマを作成する手順について

<目次> (1) Oracle DBでサンプルスキーマを作成する手順について  (1-1) はじめに  (1-2) (STEP1)ダウンロード  (1-3) (STEP2)準備  (1-4) (STE …

  • English (United States)
  • 日本語
S