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

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

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

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

解決済

2回答

5014閲覧

h2Databaseをjavaのコードの中で使いたいのです。jarファイルはeclipseのlibに入れたのですが、コードがコンパイルエラーになってしまいます。

edoooooo

総合スコア476

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2016/03/22 11:34

編集2016/03/22 12:14

eclipse内のWebcontentのWEB-INFのlibの中にh2-1.9.190jar.というファイルを入れたのですが、コードは、コンパイルエラーになってしまいます。
他にもやるべき作業があるのでしょうか?
どうぞよろしくお願いします。

以前にcon=DriverManager.getConnection("jdbc:h2:file:/Users/ta/Documents/networkspace/d/h2data.dat");
という場所を見つけ出したのですが、どういった方法で見つけたのかを忘れてしまいました。
ファイル名の指定が間違えているのでしょうか?

eclipseでのコードは

import java.sql.*;
public class Main{ //コンパイルエラー
try{
Class.forName("org.h2.Driver");
}catch(ClassNotFoundException e){//コンパイルエラー
e.printStackTrace();
}

Connection con=null;
try{
con=DriverManager.getConnection("jdbc:h2:file:/Users/ta/Documents/networkspace/d/h2data.dat");

}catch(SQLException e){//コンパイルエラー
e.printStackTrace();
}finally{
if(con!=null){
try{
con.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}//コンパイルエラー

です。 赤波線のあるコンパイルエラーの場所にはコメントを記入しました。
どうぞよろしくお願いします。

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

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

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

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

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

guest

回答2

0

質問する前に、コンパイルエラーの内容をよく読んでほしいのですが、Syntax Error(文法エラー)になっているのではないでしょうか? このエラーは、jar をどこに置いたかは関係なくて、単に、Java のプログラムとして、構文が間違っていることを示しています。

以下のように、Mainクラスの中に、メソッドを追加してください。

java

1import java.sql.*; 2 3public class Main { 4 5 public static void main(String[] args) { 6 try { 7 Class.forName("org.h2.Driver"); 8 } catch (ClassNotFoundException e) { 9 e.printStackTrace(); 10 } 11 12 Connection con = null; 13 try { 14 con = DriverManager.getConnection("jdbc:h2:file:/Users/ta/Documents/networkspace/d/h2data.dat"); 15 16 } catch (SQLException e) { 17 e.printStackTrace(); 18 } finally { 19 if (con != null) { 20 try { 21 con.close(); 22 } catch (SQLException e) { 23 e.printStackTrace(); 24 } 25 } 26 } 27 } 28}

あと、質問を入力、編集する時の入力欄の上に </> というマークがあると思います。Java などのコードを入力する時は、まず、そのボタンを押して、表示された記号の間に、コードを貼り付けてください。そうすると、コードがすごく読みやすくなりますよ。

投稿2016/03/22 13:27

tatsuya6502

総合スコア2035

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

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

edoooooo

2016/03/23 01:45 編集

ありがとうございます。 コンパイルエラーがなくなりました。  別の質問で新しい質問をさせていただきます。 ありがとうございました。
guest

0

ベストアンサー

おそらく「動的Webプロジェクト」をお使いだと思いますが、もしそうでない場合は動的Webプロジェクトをお使いください。

動的Webプロジェクトであれば、WebContent/WEB-INF/lib 以下に jarファイルを配置すれば標準では自動的にビルドパスに含まれます。

もし自動的にビルドされない場合は、次を確認してください。

  • プロジェクト>自動的にビルド をチェックしている
  • Javaリソース>ライブラリ>Web App ライブラリーが存在すること
  • Web App ライブラリーに、配置したjarファイルがいること

これらを満たせば、import文やConnectionでコンパイルエラーは出ないはずです。

投稿2016/03/22 11:46

A-pZ

総合スコア12011

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

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

edoooooo

2016/03/22 11:58

回答ありがとうございます。 教えていただいた3点を確認したのですが、条件は、満たしていました。 import のエラーがSyntax error on tokens, ClassHeader expected insteadと書いてあり、クラスは、Mainなのにpublic class Main{ がないと思いコードに足したところ、エラーが変わりました。
edoooooo

2016/03/22 12:04 編集

本のサンプルコードには、Classが書いてなかったのですが、本の意味は、eclipse内でなく、H2コンソール内にコードを書けということなのでしょうか? どうぞよろしくお願いします。
tatsuya6502

2016/03/22 13:02

これは Java のコードなので、対応としては、『クラスは、Mainなのにpublic class Main{ がないと思いコードに足した』で合ってます。 今はどんなエラーが出てますか?
tatsuya6502

2016/03/22 13:17

あ、勘違いしました。今は質問に書いたエラーが出てるのですね。別途、回答を書きますので、そちらを参照してください。
A-pZ

2016/03/23 01:09

tatsuya6502様も回答されておりますが、以下が問題でしょうか。 * package宣言 * class宣言がメソッドのようになっている
edoooooo

2016/03/23 01:48

public static void main(String[] argsを書いたところ、無事コンパイルエラーが消えました。ありがとうございます。別の質問で、データベースが使用中です。の解決法を質問させていただいているのでよろしければ、どうぞよろしくお願いします。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問