以前在做項目的時候不太了解model與entity的含義,在公司(卓~)項目中學習到了。model的字段>entity的字段,并且model的字段屬性可以與entity不一致,model是用于前端頁面數據展示的,而entity則是與數據庫進行交互做存儲用途。
舉個例子:
比如在存儲時間的類型時,數據庫中存的是datetime類型,entity獲取時的類型是Date()類型,date型的數據在前端展示的時候必須進行類型轉換(轉為String類型),在前端的進行類型轉換則十分的麻煩,轉換成功了代碼也顯得十分的臃腫,
所以將entity類型轉換后,存儲到對應的model中,在后臺做類型轉換,然后將model傳到前端顯示時,前端的就十分的干凈。
同時也可以添加字段,作為數據中轉。
具體的轉換思路,還沒具體看是怎么處理的,等后面看了補上。
補充知識:java 使用反射在dto和entity 實體類之間進行轉換
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
public class Utils { /** * 將dto和entity之間的屬性互相轉換,dto中屬性一般為String等基本類型, * 但是entity中可能有復合主鍵等復雜類型,需要注意同名問題 * @param src * @param target */ public static Object populate(Object src, Object target) { Method[] srcMethods = src.getClass().getMethods(); Method[] targetMethods = target.getClass().getMethods(); for (Method m : srcMethods) { String srcName = m.getName(); if (srcName.startsWith( "get" )) { try { Object result = m.invoke(src); for (Method mm : targetMethods) { String targetName = mm.getName(); if (targetName.startsWith( "set" ) && targetName.substring( 3 , targetName.length()) .equals(srcName.substring( 3 , srcName.length()))) { mm.invoke(target, result); } } } catch (Exception e) { } } } return target; } /** * dto集合和實體類集合間的互相屬性映射 * @param src * @param target * @param targetClass * @return */ @SuppressWarnings ( "unchecked" ) public static <S,T> List<T> populateList(List<S> src,List<T> target,Class<?> targetClass){ for ( int i = 0 ;i<src.size();i++){ try { Object object = targetClass.newInstance(); target.add((T) object); populate(src.get(i),object); } catch (Exception e) { continue ; //某個方法反射異常 } } return target; } } |
以上這篇java 后臺開發中model與entity(實體類)的區別說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/u012188107/article/details/51397442