[seasar-dotnet:2445] Re: サンプルプロジェクトの疑問

taknb2nch [E-MAIL ADDRESS DELETED]
2015年 3月 23日 (月) 20:37:47 JST


taknb2nchです。


簡単に少しだけ書かせていただきます。

私もMemberDto(ビュー用)にMember(DBFluteのエンティティ)を継承させることはしません。
当然ながらDto内にエンティティのインスタンスを保持することもしません。

JavaであろうがC#であろうが、
各レイヤー間ができるだけ疎結合になるように意識しています。


極端な例ですが、

> あーでも、DB自体がORACLE⇔SQLSERVERとかに変わったりした場合とか
> 直接参照しているといろんな使用箇所毎で影響あるかもですね。
> これが一番怖いですね。
と書かれていますが、
ある日突然、
「DBFlute使用禁止!他のORMに変更しろ!」
とか言われたどうします?

(こんなこと言われたら私も困りますが)


join先の変更や、テストコードや、その他、、、たくさん考えられると思います。

あくまで個人的な考えです。

2015年3月23日 18:54 志水正幸 <ie2m-smz @ asahi-net.or.jp>:
> 志水です。
> 超お世話になっております。
>
>
> 久保さんこんばんわ。
> 御意見ありがとうございます。
>
>> いいんですよー、でなければseasar-dotnet閑古鳥になってしまいますから。
>> 今回みたいに「みんなどう作ってる?」っての、もっと共有していきたいですね。
> そう言っていただけるだけで安心です。。。
> 一人で開発していると誰にも意見やアドバイスがもらえないので
> 色々と仕組みに関しての悩み所が多くて、迷惑かなと思いつつ質問してます。。。
> C#むずいし、汎用時代のCOBOLが一番簡単だったなぁ・・
>
>> リストを別のにするっていうよりかは、
>> DBのEntityを直接HTMLテンプレートに渡さないっていうことは意識しています。
>> (普段Javaなので、その場合はJSPになります。JSPからEntityの直接参照は禁止)
>>
>> なぜかというと、DBの変更があったときにコンパイルエラーで検知しやすいという
>> メリットでDBFluteがあるわけですが、コンパイルセーフでないHTMLテンプレートに
>> Entityを渡してしまうとい、変更があってもコンパイルエラーで検知できないからです。
>>
>> そう言う意味では、MemberDtoにMemberを継承させるってのも、
>> ぼくはやらないですね。
>>
> なるほど、JSPだと確かにカラムや属性変更があっても、
> 実際に動かすときにコンパイルされるわけだから箇所がわからないですね。
> 特に属性とかもみてもいないんでしたっけ?
> DBのEntityを直接渡さないというのも、そういう理由ならわかりますね。
>
> けど、新たに別のDTO作ってやるのって結構大変ですね。
> みんなお手製なんですか?
> ツールとかあればっていつも思ってしまうんです(笑)
> 自動で作るツールをつくろうと思ってもスキルないので無理(笑)
> 最近、dynamicや<T>とかでクラス指定できるんだって知ったばかりなので。。
> ずっとOBJECT使ってキャストしてました(笑)
>
> MemberDtoにMember継承させてやるような仕様にしている私でも
> コピーメソッド作るのがあまりにも大変だったし、
> 変更したら手直しいるしで、今回からAutoMapperでポイッとコピーしてます。
>
> JSPと違い、ASP.NETだと画面へ渡す箇所で変更があった場合は検知できますね。
> 属性が変わった場合も大概エラーになるし。
> この辺は言語仕様の違いなので、.NETは別のリスト作らなくてもいいような気もするけど
> 今はDBアクセスなどはLogicクラス介してILISTのDTOを返却するような形にしていて
> 一応の切り分けをしているので、
> なんか、今更DBのEntityを直接使用するのはちょっと気持ち悪い気もするし
>
> あーでも、DB自体がORACLE⇔SQLSERVERとかに変わったりした場合とか
> 直接参照しているといろんな使用箇所毎で影響あるかもですね。
> これが一番怖いですね。
>
> ちょっと生産性的や稼働には非効率だけれども
> 保守的なことを考えると
> DTOに一旦渡すやり方が、一元管理もできるし良い気がしてきました。
> でも全部お手製はいやなので、MemberDtoにMemberを継承すような方法で
> カラム単位で影響がでた場合は
> MemberDtoに影響あるカラムをあれコレする手法がいいかな~
>
> うちはこんなやり方で生産性や保守を効率的にしている~
> とか、いやこんなやり方は邪道だーとか
> あまり難しいことはわからないのですが
> ご意見などご教示しただければと思います。
>
>
>
>
>
>
>> 久保(jflute)です
>>
>>>  返却されてきたPagingResultBeanをそのまま使った方が効率いいように思うの ですが
>>>  サンプルの「dbflute.net-asp.net-example」はなぜ、一旦別のリストに移し 替えているのでしょうか?
>> リストを別のにするっていうよりかは、
>> DBのEntityを直接HTMLテンプレートに渡さないっていうことは意識しています。
>> (普段Javaなので、その場合はJSPになります。JSPからEntityの直接参照は禁止)
>>
>> なぜかというと、DBの変更があったときにコンパイルエラーで検知しやすいという
>> メリットでDBFluteがあるわけですが、コンパイルセーフでないHTMLテンプレートに
>> Entityを渡してしまうとい、変更があってもコンパイルエラーで検知できないからです。
>>
>> そう言う意味では、MemberDtoにMemberを継承させるってのも、
>> ぼくはやらないですね。
>>
>>
>>
>>> 最近、私ばかり質問しているようで恐縮してしまうばかりで
>>> なんか本当にすいません。
>> いいんですよー、でなければseasar-dotnet閑古鳥になってしまいますから。
>> 今回みたいに「みんなどう作ってる?」っての、もっと共有していきたいですね。
>>
>> 2015-03-23 13:25 GMT+09:00 志水正幸 <ie2m-smz @ asahi-net.or.jp>:
>>> 志水です。
>>> 超お世話になっております。
>>>
>>>
>>> 最近、私ばかり質問しているようで恐縮してしまうばかりで
>>> なんか本当にすいません。
>>>
>>> 元々、初めてのC#とASP.NETのダブルの独学だったので
>>> あまり細かいところに意識が回らなかった私が悪いですが
>>> 今回、新たにプロジェクトを作成した際にマニュアルやサンプルを見なおしていて
>>> 自分の使い方が正しいのかどうかがよくわからなくなりました。
>>> ※サンプルは  「dbflute.net-quill-example」  「dbflute.net-asp.net- example」
>>> を見ていました。
>>>
>>> 現在のプロジェクトを作成するにあたり参考にしたのが
>>> サンプルの「dbflute.net-asp.net-example」で
>>> このプロジェクトには
>>> 「DfExampleBiz」プロジェクトに
>>> 「Facade」 > 「Dto 」
>>>   MemberDto
>>>   MemberDtoList
>>> が作成されておりまして、これらを使って画面に表示させるような仕組みでした。
>>> 今までやってきたJavaとかは、普通にBeanとか手作りだったので
>>> これが普通にしっくりきたんですね。
>>>
>>> サンプルを真似して、今のプロジェクトは
>>> 「ExEntity」のMemberを継承させたMemberDtoを作成しています。
>>> **************************************************************************************
>>> ↓↓↓こんな感じです。↓↓↓
>>> PagingResultBean<DfExample.DBFlute.ExEntity.Member> page =
>>> memberBhv.SelectPage(cb);
>>>             list.AllRecordCount = page.AllPageCount;
>>>
>>>             foreach (var member in page)
>>>             {
>>>                 MemberDto dto = new MemberDto();
>>>
>>>                 ここで、全プロパティをコピー
>>>
>>>                 list.MemberList.Add(dto);
>>>             }
>>> **************************************************************************************
>>>
>>> また、InsertやUpdate、DeleteのメソッドにはMemberに移し替えることはせず、
>>> MemberDto をそのまま渡しています。
>>>
>>>
>>> <疑問点>
>>>  まだまだ、よくわかってないことがいっぱいあるので変なこと言っているかも しれないのですが
>>>  返却されてきたPagingResultBeanをそのまま使った方が効率いいように思うの ですが
>>>  サンプルの「dbflute.net-asp.net-example」はなぜ、一旦別のリストに移し 替えているのでしょうか?
>>>  みなさん、どのような仕組みされていますか?
>>>
>>> 以上、ご教示お願いします。
>>>
>>>
>>>
>>>
>>>
>>> ---
>>> このEメールはアバスト アンチウイルスによりウイルススキャンされています。
>>> http://www.avast.com
>>>
>>> _______________________________________________
>>> seasar-dotnet mailing list
>>> seasar-dotnet @ ml.seasar.org
>>> https://ml.seasar.org/mailman/listinfo/seasar-dotnet
>> _______________________________________________
>> seasar-dotnet mailing list
>> seasar-dotnet @ ml.seasar.org
>> https://ml.seasar.org/mailman/listinfo/seasar-dotnet
>>
>
> _______________________________________________
> seasar-dotnet mailing list
> seasar-dotnet @ ml.seasar.org
> https://ml.seasar.org/mailman/listinfo/seasar-dotnet


seasar-dotnet メーリングリストの案内