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

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

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

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Q&A

2回答

4482閲覧

複数テーブルが存在するアプリにおけるDTOの設計について

potato_taro

総合スコア2

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

0グッド

1クリップ

投稿2020/07/05 11:13

編集2020/07/05 11:16

複数テーブルが存在し、かつ複数テーブル感でリレーションのある場合に、DTOやDAOをどのように設計すべきか悩んでおります。以下、5テーブルがあるとします。

items

1id 2name 3maker_id 4size_id

sizes

1id 2size (S,M,L)

makers

1id 2name

orders

1id 2customer_id 3item_id 4quantity

上記5テーブルに対し、現状makerとitemのDTOがあります。

MakerDto

1public class MakerDto { 2 private String name; 3 // getter, setter 4}

ItemDto

1public class ItemDto { 2 private String name; 3 private MakerDto maker; 4 private // SizeDto size ? int sizeID ? 5 // getter, setter 6}

ここで疑問に思ったのですが、サイズテーブルもDTO化すべきでしょうか?
DTO化するとなると、テーブル全てをDTO化することになり、テーブルの数だけDTOができてしまうので、現状は問題ないですがいずれ膨大な数になってしまうと思います。
しかしアプリケーションの中でサイズを使いたいとなれば、IDだけ持ってても、また検索が必要になるのでそれもないよな...とも思っております。

このような場合、どのようなアプローチが適切なのでしょうか。

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

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

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

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

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

guest

回答2

0

DTO化するとなると、テーブル全てをDTO化することになり、テーブルの数だけDTOができてしまう

これについては特に問題ありません。

理由として大量に増えたとしても業務ドメインや機能がわかれる=パッケージが分離するものですし、IDEを利用して検索やクラスを辿って表示も可能なので、正しくグループ分けができればさほど気になりません。

投稿2020/07/07 12:53

A-pZ

総合スコア12011

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

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

0

汎用的なDTOは持っておいても構わないかと思いますが、そこは要件次第。
別のテーブルのために同じDTOを共有するのはあまりよろしくないと思います。
まずは設計を確定されてはどうでしょうか。
あまり共有しすぎると、仕様変更に弱い作りになるのではと言う懸念はあります。
依存しすぎも良くないですが、汎用しすぎも良くはないです。
ただ、それもアプリケーション自体の目的にもよるので、
やはり、もっと全体と今後のことを考えた上で設計し、データの持ち方を考えるべきと思います。

投稿2020/07/05 11:37

m.ts10806

総合スコア80875

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

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

potato_taro

2020/07/05 12:25

ご回答いただきありがとうございます。 >別のテーブルのために同じDTOを共有するのはあまりよろしくない というのは、私の例で挙げたItemDtoがMakerDtoを持つような事例のことでしょうか?
m.ts10806

2020/07/05 12:29

いえ、リレーションがあるのなら、むしろ持っておいた方が良いですし、その例は「共有」ではなく「保有」です。 私が意図しているのは「汎用的なDTO」のことです。 例えば「CommonDto」のような名前で「id . name」だけ持っておくとかそういうもののことです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問