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

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

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

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

3回答

10730閲覧

eclipsでJavaからデータベースにアクセスして、テーブル一覧をコンソールに表示させたいです。

sarasa7

総合スコア13

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

1クリップ

投稿2015/06/24 14:56

eclipsを使ってJavaからSQLのテーブル一覧をコンソールに表示させたいのですが、テーブルが表示されないです。JDBCを使って、oracleに繋げることはできました。コンパイルエラーは出ず、実行はされますが、テーブルは表示されずに処理が終了してしまいます。下記のようにコードを記述したのですが、何か間違っているのでしょうか。

lang

1コードpublic void indicate () { 2 try{ 3 Class.forName("oracle.jdbc.driver.OracleDriver"); 4 String url = "jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = XXXX)(PORT = 1521))(CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME = oracle)))"; 5 String user = "hr"; 6 String pass = "hr"; 7 Connection con = DriverManager.getConnection(url, user, pass); 8 Statement stmt = con.createStatement(); 9 ResultSet rset = stmt.executeQuery ("select * from EMP"); 10 while (rset.next()) { 11 System.out.println( 12 rset.getInt("ID") + "¥t" 13 + rset.getString("商品名") + "¥t" 14 + rset.getString("製作者") + "¥t" 15 + rset.getString("会社名") + "¥t" 16 + rset.getDate("発売日") + "¥t" 17 + rset.getInt("値段")); 18 } 19 rset.close(); 20 stmt.close(); 21 con.close(); 22 } catch (ClassNotFoundException e) { 23 e.printStackTrace(); 24 } catch (SQLException e) { 25 e.printStackTrace(); 26 } 27 }

それともeclipsのコンソール画面では表示されないのでしょうか。
わかりづらくてすみません。
どなたか原因や表示させる方法を知っている方がいましたら教えてください。

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

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

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

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

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

guest

回答3

0

ベストアンサー

・実行時のエラーメッセージは出ていませんか?
while の次のSystem.out.printlnには、空白以外の文字も出力されるようにしてみましょう。
・それでも何も出力されなければ、empにレコードが無い可能性はないですか?

投稿2015/06/24 15:03

argius

総合スコア9388

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

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

sarasa7

2015/06/29 13:42

ありがとうございます。どうやらレコードがなかったみたいです。Javaからinsert文を実行してからselect文を実行すると表示されるようになりました。
guest

0

eclipse をつかっているなら、ステップ実行をさせることができるはずです。
1ステップずず実行をさせ、変数の値の変化を確認してみては?

とくに 次の点を確認することが必要です。
rest の変数に値が設定できているか,
while 文の中に制御が移っていっているか

投稿2015/06/24 21:29

編集2015/06/29 21:40
katoy

総合スコア22324

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

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

sarasa7

2015/06/29 13:37

ステップ実行は知りませんでした。教えていただきありがとうございます。その2点についてはちゃんと処理ができていたみたいでした。
guest

0

回答ではないですが、気になったので一点だけ :)

レコード内容の出力部でタブ文字を使用したいように見えるのですが、
全角("¥t")だとそのまま出力されてしまいます。
半角("\t")に修正するとタブ文字になりますので、問題解決後お試しください :D

投稿2015/06/24 15:23

ryunix

総合スコア1656

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

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

sarasa7

2015/06/29 13:40

ご指摘ありがとうございます。ちゃんと直しておきます。
ryunix

2015/06/29 13:45

はい! 問題も解決したみたいで良かったです :D
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問