av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

java - Mybatis 一對多怎么映射

瀏覽:109日期:2023-11-30 09:23:31

問題描述

比如有一個實體類

public class AnswerDto{ //一個回復的類,一個問題可能會有多個回復 int id; int askId;//問題id List<String> answers; //回復的列表}

java - Mybatis 一對多怎么映射

我原本這么寫,但是是錯的 T0T, 應該如何將content映射到List<String>

<select parameterType='int' resultMap='uiy'> select id, ask_id AS 'askId', content from t_answer where ask_id = #{_parameter}</select><resultMap type='AnswerDto' id='uiy'> <id property='id' column='id'/> <result property='askId' column='askId' /> <collection property='ls' ofType='string'><constructor> <arg column='content'/></constructor> </collection></resultMap>

問題解答

回答1:

mybatis是根據<id>標簽確定集合映射關系的, 如果一定要用你這個表的話可以這樣映射

<id column='askId' property='askId' /><result column='id' property='id'/><collection property='answers' ofType='java.lang.String' javaType='java.util.List'> <result column='content' /></collection>回答2:

樓主這里應該還少了一張表,就是問題表。

配合問題表,DTO的定義應該是這樣的。

public class QuestionDTO { int questionId; String questionDesc; List<AnswerDTO> answers; // Answers of the question int created; // 創建時間 int updated; // 更新時間}public class AnswerDTO{ //一個回復的類,一個問題可能會有多個回復 int id; int questionId; // 問題id String content; // 答案內容 int created; // 創建時間 int updated; // 更新時間}

這個時候 mybatis 的關聯查詢解決方案有很多,我附上一個鏈接吧。

Mybatis關聯查詢(嵌套查詢)

mybatis 的關聯查詢網上資料蠻多的,樓主可以多搜搜。

最后提一個建議,最好不要進行關聯查詢。數據的組裝邏輯放在代碼里面來做,這樣方便以后 DB 的改造。因為隨著數據量越來越大,關聯查詢性能比較糟糕,還不容易做分庫分表的改造,不過這都是建立在業務有大量增長的情況下。當前的話,樓主開始培養這個意識就好啦。

回答3:

表字段到復雜對象字段的映射可以采用自定義TypeHandler的方式搞定。eg:MyBatis里json型字段到Java類的映射http://www.cnblogs.com/watery...

標簽: java
相關文章:
主站蜘蛛池模板: 国产不卡在线观看 | 九色国产 | 亚洲资源在线 | 欧美一级在线 | 99久久久久国产精品免费 | 久久一 | 在线a视频网站 | 亚洲欧洲在线视频 | www.久久久久久久久 | 色99视频 | 久久国产精品精品国产色婷婷 | 自拍中文字幕 | 日韩精品免费在线观看 | 国产精品自拍一区 | 午夜天堂精品久久久久 | 中文字幕一区二区三区四区 | 欧美日韩一区二区三区四区 | 雨宫琴音一区二区在线 | 亚洲成人一区 | 欧美精品1区2区3区 免费黄篇 | 国产成人在线播放 | 国产一区二区在线播放视频 | 欧美6一10sex性hd | 日韩精品一区二区三区视频播放 | 亚洲天堂一区二区 | 黄色三级在线播放 | 日韩精品在线免费观看视频 | 看一级毛片 | 国外成人在线视频网站 | 日韩av中文 | 亚洲综合99| 欧美一区二区三区久久精品 | 麻豆精品国产免费 | 99久久精品国产一区二区三区 | av看片网站 | 91成人免费看 | 欧美中文字幕在线观看 | 欧美天堂| 中文字幕一区在线观看视频 | 久久精品亚洲一区二区三区浴池 | 久久大陆 |