Oracle9i R2にJDBCで接続してCUSTOMER表のレコード件数を調べる単純なJavaプログラムをつくろうとしています。
以下のソースをOracle端末上で実行すると「Exception in thread "main" java.lang.NoClassDefFoundError: CUSTOMER」というエラーメッセージが表示されます。
環境設定としてCLASSPATHにclasses12.zipのパスを通しました。
-------------------------------------------------
// JDBC APIのインポート
import java.sql.*;class CUSTOMER {
public static void main (String args[])
throws SQLException, ClassNotFoundException {
// JDBC Driverの登録
Class.forName("oracle.jdbc.driver.OracleDriver");
// Oracle9iに接続
Connection conn =
DriverManager.getConnection ("jdbc:oracle:thin@192.168.0.10:1521:testdb", "test", "test");
// ステートメントを作成
Statement stmt = conn.createStatement();
// 問い合わせの実行
ResultSet rset = stmt.executeQuery("SELECT COUNT(*) FROM CUSTOMER");
// 問い合わせ結果の表示
while ( rset.next() ) {
// 列番号による指定
System.out.println(rset.getInt(1) + "\t" + rset.getString(2));
}
// 結果セットをクローズ
rset.close();
// ステートメントをクローズ
stmt.close();
// 接続をクローズ
conn.close();
}
}
-------------------------------------------------
何かおわかりの方いらっしゃいましたら教えて下さい。宜しくお願いします。
No.7
- 回答日時:
>Connection conn =
>DriverManager.getConnection ("jdbc:oracle:thin@192.168.0.10:1521:testdb", "test", "test");
Exceptionのメッセージ通り、この部分がおかしいようです。
IPアドレス及びポート番号、SID、ユーザー、パスワードはあっていますか?
参考URL:http://www.techscore.com/tech/Java/JDBC/oracle-1 …
No.6
- 回答日時:
三度,#3です.
ひとまずNoClassDefFoundErrorの問題はクリアでよかったですね.
ソースを見て気づいたことがあります.
SQL文ではで"SELECT COUNT(*) ..."としていますね.
そうすると,rset.getString(2)ではおかしなことになります.
整数値が入るフィールドから文字列を読み込めないからです.
SELECT * FROM CUSTOMER;
とすべきではないですか?
これがエラーの原因かどうか分かりませんが...
No.5
- 回答日時:
#2です。
CUSTOMER.classがC:\WORKに存在している場合で
cd C:\WORK
java -classpath C:\WORK CUSTOMER
でやってみてください。
No.4
- 回答日時:
#3です.お返事ありがとうございました.
Windows環境下ということですが,CLASSPATHの設定はマイコンピュータのプロパティの中にある「環境設定」で行われているんですよね?
憶測ですが,コマンドプロンプトで実行されているのではないかと思います.
もしもそうならば,環境設定の変更は一度コマンドプロンプトを終了しないと,反映されません.
試しに,SETと入力して見て下さい.
もしも変更が反映されていないならば,一度終了して再度実行してみて下さい.
lively-gonさん、ご回答有難うございました。
すみません、コマンドプロンプトを終了させずに実行しようとしておりました。
今、コマンドプロンプトを一度終了し、再度立ち上げて実行したところおっしゃるとおりエラーメッセージが変りました。
引き続き質問して恐縮ですが、無効なOracle URLとはどこの記述が悪いのでしょうか?
-------------------------------------------------
Exception in thread "main" java.sql.SQLException: 無効なOracle URLが指定されまし
た。
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:269)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:188)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at CUSTOMER.main(syn_cust.java:17)
-------------------------------------------------
No.3
- 回答日時:
こんにちは
CLASSPATHの設定はどのようになっていますか?
CLASSPATH=x:\yyy\classes12.zip (Windowsの場合)
という感じですか?
もしもそうだったら
CLASSPATH=.;x:\yyy\classes12.zip
のように,ピリオドとセミコロンを最初に付けてみて下さい.
ピリオドはカレントディレクトリを示しています.
lively-gonさん、ご回答有難うございます。
本件はWindows環境です。ご指摘どおり「.;」を最初につけて試してみましたが、結果は同じになってしまいました。。
No.2
- 回答日時:
CUSTOMER.classはできていますか?
実行しているカレントディレクトリに
CUSTOMER.classがありますか?
CUSTOMER.classがC:\WORKに存在している場合
cd C:\WORK
java CUSTOMER
として実行してみてください。
ソースに間違いがいくつかあるようですので
違うエラーが出ると思います。
potedoraさん、ご回答有難うございます。
CUSTOMER.classはカレントディレクトリ(F:\直下)にございます。javacコマンドでエラーなくコンパイルできました。しかし、java CUSTOMERを入力すると、このメッセージが出ます。
どうしてでしょうか
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
eclipseでスタックサイズを変更...
-
Eclipse(JAVA)のデバッグで他...
-
Javascriptの値をJava(JSP)へ渡...
-
「ワークスペースをビルド中」...
-
JAVAにのeclipseに関する質問で...
-
split関数で区切り文字がない場合
-
Javaで年月の取得(YYYYMM形式で)
-
ExcelVBA グラフの軸ラベル ユ...
-
コミット前の更新データをチェ...
-
エクリプスで実行時、最新クラ...
-
Eclipseで作成したクラスを他の...
-
javacでStackOverflowError
-
バイナリーコードと、ソースコ...
-
NoClassDefFoundError: javax/m...
-
Javascriptのパーミッション
-
実行可能jarを実行できない
-
javaのJarファイル実行でエラー
-
eclipse実行ができない
-
eclipseで「サーバーで実行」表...
-
Eclipseで実行>Javaアプリケー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
split関数で区切り文字がない場合
-
eclipseでスタックサイズを変更...
-
「ワークスペースをビルド中」...
-
Eclipse(JAVA)のデバッグで他...
-
JAVAにのeclipseに関する質問で...
-
コミット前の更新データをチェ...
-
Javascriptの値をJava(JSP)へ渡...
-
Javaで年月の取得(YYYYMM形式で)
-
環境変数設定で
-
Eclipseで実行>Javaアプリケー...
-
jasper.exceptionとは?
-
Javascriptのパーミッション
-
NoClassDefFoundError: javax/m...
-
eclipseのjavaを実行できない
-
エクセルマクロエラー'Global'...
-
javaからVBAを実行する方法を教...
-
エクリプスで実行時、最新クラ...
-
Google Colabでimport soxが出...
-
Eclipse 実行→Javaアプリケー...
-
javascriptで、style undefined...
おすすめ情報