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

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

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

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Java

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

iBATIS

iBATISとは、O/Rマッピングフレームワークです。簡単にデータベースとJavaオブジェクトをマッピングできるO/Rマッピング機能と、DAOパターン用フレームワークで構成されています。

Q&A

解決済

1回答

6891閲覧

MybatisGeneratorで列名がキャメルケースのテーブルのコードを生成したい

fsk5303

総合スコア21

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Java

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

iBATIS

iBATISとは、O/Rマッピングフレームワークです。簡単にデータベースとJavaオブジェクトをマッピングできるO/Rマッピング機能と、DAOパターン用フレームワークで構成されています。

0グッド

1クリップ

投稿2018/11/27 09:36

編集2018/11/27 09:39

前提・実現したいこと

MybatisGeneratorで列名がキャメルケースのテーブルのコードを生成したいと思っています。
使用しているデータベースはPostgreSQLです。
※テーブルの列名にキャメルケースを用いるべきではないという事は把握しているため、その点に関するご指摘は今回は排除して頂けたらと思います。

以下のようなテーブルについて考えます。

SQL

1CREATE TABLE "public"."CamelCaseTable" 2( 3 "userId" character varying(10) NOT NULL, 4 "userPassword" character varying(10), 5 "userName" character varying(10), 6 CONSTRAINT "CamelCaseTable_pkey" PRIMARY KEY ("userId") 7)

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

MybatisGeneratorで列名がキャメルケースのテーブルのコードを生成した場合、生成されるMapper.xmlファイルは以下のようになります。
※一部を抜粋

XML

1 <sql id="Base_Column_List" > 2 userId, userPassword, userName 3 </sql> 4 5 <select id="selectByPrimaryKey" resultMap="BaseResultMap" 6 parameterType="java.lang.String" > 7 select 8 <include refid="Base_Column_List" /> 9 from "public"."CamelCaseTable" 10 where userId = #{userid,jdbcType=VARCHAR} 11 </select>

この自動生成されたコードを利用すると、以下のようなエラーが発生します。

### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: 列"userid"は存在しません

この問題を解決する良い手段はありますでしょうか。自動生成されたコードに手を加える事無く実現したいと考えています。
※例えばSQL文中の「userId」を「"userId"」に修正するようなダブルクォーテーションで囲う修正を全てのカラムについて行えば解決は可能ですが、膨大な量の修正が必要なため現実的ではありません。また、コードの自動生成をするたびに修正が必要になってしまいます。

試したこと

generatorConfig.xmlにて以下のような置換を行って自動生成すれば出来ないかなと思いましたが、
こちらで置換されるのはSQL文の方ではなくJavaクラスのプロパティの方でした。

<table catalog=" " schema="public" tableName="%"> <columnRenamingRule searchString="^" replaceString="&quot;" /> </table>

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

PostgreSQL 9.5.10
org.mybatis 3.4.4
org.mybatis.generator 1.3.0
OpenJDK 1.8.0_151

最後に

仕事で上記問題の解決を行う必要が有り、困っております。
どなたか知恵を貸していただけると幸いです。
宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

MybatisGeneratorの設定ファイルに以下を追加してみてください。

<table schema="public" tableName="CamelCaseTable" delimitIdentifiers="true" delimitAllColumns="true"/>

投稿2018/11/28 02:11

unk

総合スコア41

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

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

fsk5303

2018/11/28 02:17

まさしく希望通りの動作です。 ありがとうございました! 今後ともよろしくお願い致します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問