次のクラスがあるとします。
class A1 {
List<B1> bList;
}
class B1 {
Long id;
}
---
class A2 {
List<Long> bList;
}
A1.bList には B1 オブジェクトが含まれ、A2.bList には B1 オブジェクトの ID のみが含まれるクラス A1 を Dozer を使用して A2 にマップしたいと考えています。
マッピングはどのようになりますか?
ありがとうございました。
次のクラスがあるとします。
class A1 {
List<B1> bList;
}
class B1 {
Long id;
}
---
class A2 {
List<Long> bList;
}
A1.bList には B1 オブジェクトが含まれ、A2.bList には B1 オブジェクトの ID のみが含まれるクラス A1 を Dozer を使用して A2 にマップしたいと考えています。
マッピングはどのようになりますか?
ありがとうございました。
Long
toへのマッピングを設定してみてくださいB1
。これが一方向にしか機能しないことを正しく覚えていれば、どちらの方向か思い出せません。申し訳ありませんが、これがお役に立てば幸いです。
これは、 B1のtoString()メソッドをオーバーライドすることで実行でき、機能すると思います。
サンプルコードは次のとおりです。
@Override
public String toString() {
return new String(this.id);
}
また、マッピングで次の変更を行います。
<field>
<a>bList</a>
<b>bList</b>
<a-hint>B</a-hint>
<b-hint>java.lang.Long<b-hint>
</field>
したがって、ドーザーがB1をバインドしようとすると、そのIDが文字列として返され、ドーザーは文字列とロングの間の自動変換を実行します。
ドーザー カスタム コンバーターを使用できます。ドーザー カスタマー コンバーター
例: (考えられるエラー、コンパイルもテストもしていません)
<mapping>
<class-a>A1</class-a>
<class-b>A2</class-b>
<field custom-converter="converters.YourCustomConverter">
<a>bList</a>
<b>bList</b>
</field>
</mapping>
カスタム コンバーター:
public class YourCustomConverter implements CustomConverter {
public Object convert(Object destination, Object source, Class destClass, Class sourceClass) {
if (source == null) {
return null;
}
if (source instanceof List<?>) {
List<?> list = ((List<?>) source);
if (list.isEmpty()) {
return null;
}
if (list.get(0) instanceof B1) {
List<Long> longList = new ArrayList<Long>();
for (B1 b1 : list) {
longList.add(b1.getId());
}
return longList;
} else (list.get(0) instanceof Long) {
// do the inverse of the above
} else {
throw new MappingException("Wrong type ...");
}
} else {
throw new MappingException("Converter YourCustomConverter used incorrectly. Arguments passed in were:"
+ destination + " and " + source);
}
}
}