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

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

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

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

JDBC

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

Java

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

Apache Maven

Apache Mavenは、ソフトウェアプロジェクトの管理ツールです。

Q&A

解決済

1回答

2072閲覧

ソースを書き換えることなくmvnのオプションだけでJDBCドライバを切り替えたい。

naomi3

総合スコア1105

XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

JDBC

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

Java

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

Apache Maven

Apache Mavenは、ソフトウェアプロジェクトの管理ツールです。

0グッド

0クリップ

投稿2021/02/13 05:33

前提・実現したいこと

JavaでWebシステムを作っています。開発環境とリリース環境で使用するOracleDBのバージョンが異なるので、Javaソースやpom.xmlを書き換えることなく、mvnコマンドのオプションだけでJDBCドライバを切り替え、warファイルをインストールしたいです。profile要素やactivation要素を使うところまでは分かったのですが、dependency要素が下記だけではなく多くあるので、重複記述なくpom.xmlを書こうとして詰まってしまいました。もっとも、OracleDBのJDBCドライバはMavenセントラルリポジトリにないので、mvnコマンドでJDBCドライバを手動インストールしなければならず、手間がそれほど軽減されるわけではないのですが。Javaからの接続は環境変数で切り替えてうまくいっています。よろしくお願いします。

発生している問題・エラーメッセージ

<artifactId>${jdbc.artifactId}</artifactId>のところで文法エラーになります。

該当のpom.xml(抜粋)

xml

1 <profiles> 2 <profile> 3 <id>develop</id> 4 <activation> 5 <activeByDefault>true</activeByDefault> 6 </activation> 7 8 <properties> 9 <jdbc.artifactId>ojdbc6_g</jdbc.artifactId> 10 <jdbc.version>11.2.0</jdbc.version> 11 </properties> 12 </profile> 13 14 <profile> 15 <id>release</id> 16 <properties> 17 <jdbc.artifactId>ojdbc8_g</jdbc.artifactId> 18 <jdbc.version>18.4.0</jdbc.version> 19 </properties> 20 </profile> 21 22 </profiles> 23 24 <dependencies> 25 <dependency> 26 <groupId>oracle</groupId> 27 <artifactId>${jdbc.artifactId}</artifactId> 28 <version>${jdbc.version}</version> 29 </dependency> 30 31 </dependencies> 32

補足情報(FW/ツールのバージョンなど)

Apache Maven 3.6.3、Eclipse 4.6.2

開発環境:Oracle Database Express Edition 11g
リリース環境:Oracle Database Express Edition 18c

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

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

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

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

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

naomi3

2021/02/25 12:15

返信が遅くなりました。 以前はMavenセントラルリポジトリがなかったはずなので、情報ありがとうございました。 手動インストールする手間が省けました。
guest

回答1

0

ベストアンサー

profileごとにdependencyを切り替えたい場合は、profileの中にdependencyを定義することで実現できます。

xml

1<profiles> 2 <profile> 3 <id>develop</id> 4 <activation> 5 <activeByDefault>true</activeByDefault> 6 </activation> 7 <dependencies> 8 <dependency> 9 <groupId>oracle</groupId> 10 <artifactId>ojdbc6_g</artifactId> 11 <version>11.2.0</version> 12 </dependency> 13 </dependencies> 14 </profile> 15 16 <profile> 17 <id>release</id> 18 <dependencies> 19 <dependency> 20 <groupId>oracle</groupId> 21 <artifactId>ojdbc8_g</artifactId> 22 <version>18.4.0</version> 23 </dependency> 24 </dependencies> 25 </profile> 26</profiles>

もっとも、OracleDBのJDBCドライバはMavenセントラルリポジトリにないので、mvnコマンドでJDBCドライバを手動インストールしなければならず、手間がそれほど軽減されるわけではないのですが。

このような場合はdependencyのscopeをsystemにして対応することが多いかと思います。

投稿2021/02/13 08:00

neko_the_shadow

総合スコア2230

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

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

naomi3

2021/02/25 12:22

dependencies要素が複数で書けたのですね。ありがとうございます。Eclipseでもプロファイルを切り替えられてすっきりしました。 最終的には以下のようにしました。 <profiles> <profile> <id>develop</id> <activation> <activeByDefault>true</activeByDefault> </activation> <dependencies> <dependency> <!-- https://mvnrepository.com/artifact/com.oracle.database.jdbc.debug/ojdbc6_g --> <groupId>com.oracle.database.jdbc.debug</groupId> <artifactId>ojdbc6_g</artifactId> <version>11.2.0.4</version> </dependency> </dependencies> </profile> <profile> <id>release</id> <activation> <activeByDefault>false</activeByDefault> </activation> <dependencies> <dependency> <!-- https://mvnrepository.com/artifact/com.oracle.ojdbc/ojdbc8_g --> <groupId>com.oracle.ojdbc</groupId> <artifactId>ojdbc8_g</artifactId> <version>19.3.0.0</version> </dependency> </dependencies> </profile> </profiles>
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問