springboot+mybatis 實現(xiàn)對數(shù)據(jù)的CRUD

搞事情

在沒有接觸mybatis之前我都是用springmvc+jdbc做的數(shù)據(jù)庫操作,接觸mybatis之后對數(shù)據(jù)庫的操作變得簡單了很多,并且項目層次更加清晰,廢話不多說 直接上代碼,springboot搭建我就不說了,不了解的直接跳轉(zhuǎn):IntelliJ IDEA搭建SpringBoot

注解說明:下面例子中會用到一些注解,在此統(tǒng)一說明下

@Mapper: DAO 接口類的注解,所有接口直接調(diào)用mybatis.xml,下面有講解

@Data: DO 數(shù)據(jù)模型注解, mybatis查詢后可直接放回數(shù)據(jù)模型,也可在查詢時傳入

@Param: mapper傳入?yún)?shù)(DAO中使用)


配置說明

在resource下創(chuàng)建mybatis文件夾,mybatis文件夾中包含mapper文件夾(此文件夾中是所有業(yè)務(wù)的CRUD) 和 mybatis-config.xml


mybatis配置

然后就是在application配置文件中增加配置項,我使用的是.yml配置,配置如下:

指定mybatis配置路徑和mapper路徑


最后在pom中增加依賴

到此為止已經(jīng)配置完畢,可以開始coding了



下面寫幾個簡單的例子分別講一下不同情況時如何使用

dao層定義接口

創(chuàng)建DO數(shù)據(jù)模型

在mapper文件夾中創(chuàng)建UserMapper.xml文件

其中namespace 是 DAO接口類的路徑

resultMap:定義查詢數(shù)據(jù)后的返回, type指定DO數(shù)據(jù)模型, result是映射關(guān)系,數(shù)據(jù)字段映射到DO字段.

sql:定義的查詢字段集

在UserMapper.xml中添加插入配置

insert 代表插入, 其余的還有 update,select,delete

id: 對應(yīng)DAO中的接口名稱, 向上翻看是否與 dao層定義接口 名稱相同

#{param}固定寫法

此時一條用戶注冊數(shù)據(jù)插入就實現(xiàn)了.

除了普通數(shù)據(jù)插入也直接在DAO層直接傳入DO數(shù)據(jù)模型,但必須要在mybatis-config.xml文件中配置

除了基本數(shù)據(jù)類型的配置 也可以配置DO數(shù)據(jù)模型,配置好后我們繼續(xù)

將上述DAO接口參數(shù)改為 User user后UserMapper.xml 對應(yīng)的#{phone}等就可以改成user.phone

當插入數(shù)據(jù)量較大時建議先創(chuàng)建DO數(shù)據(jù)模型, 然后在進行插入查處 后期也方便維護.



查詢數(shù)據(jù)

以查詢用戶為例

mapper.xml如下

resultMap指定查詢的結(jié)果以map方式返回,UserResultMap在上面有配置,所有返回的結(jié)果可以直接用UserDO接收,DAO定義如下



以上就是大致的用法的了,delete,update操作就不講了.下面將一下在mybatis中如何使用if 和when進行條件查詢

如上圖中 使用到了兩個條件語句 <if> 和 <choose>, 其中<if>為單條件判斷,mybatis中沒有 if else語法 取而代之的是 <choose>語法.

場景: 根據(jù)多個用戶id查詢用戶列表

此處用到了<foreach>語句,? 其中collection是DAO中傳入的 List<String> userIds,也可以傳入String[] userIds.

到此mybatis就差不多了, 我也是第一次分享, 有不足的大家見諒哈

by:張鼎輝

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市龄捡,隨后出現(xiàn)的幾起案子焊傅,更是在濱河造成了極大的恐慌缅茉,老刑警劉巖巡通,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谆棺,死亡現(xiàn)場離奇詭異睁搭,居然都是意外死亡砸逊,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進店門游盲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來误墓,“玉大人,你說我怎么就攤上這事益缎。” “怎么了然想?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵莺奔,是天一觀的道長。 經(jīng)常有香客問我变泄,道長令哟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任妨蛹,我火速辦了婚禮屏富,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛙卤。我一直安慰自己狠半,他們只是感情好噩死,可當我...
    茶點故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著神年,像睡著了一般已维。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上已日,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天垛耳,我揣著相機與錄音,去河邊找鬼飘千。 笑死堂鲜,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的护奈。 我是一名探鬼主播泡嘴,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼逆济!你這毒婦竟也來了酌予?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤奖慌,失蹤者是張志新(化名)和其女友劉穎抛虫,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體简僧,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡建椰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了岛马。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棉姐。...
    茶點故事閱讀 39,739評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖啦逆,靈堂內(nèi)的尸體忽然破棺而出伞矩,到底是詐尸還是另有隱情,我是刑警寧澤夏志,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布乃坤,位于F島的核電站,受9級特大地震影響沟蔑,放射性物質(zhì)發(fā)生泄漏湿诊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一瘦材、第九天 我趴在偏房一處隱蔽的房頂上張望厅须。 院中可真熱鬧,春花似錦食棕、人聲如沸朗和。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽例隆。三九已至甥捺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間镀层,已是汗流浹背镰禾。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留唱逢,地道東北人吴侦。 一個月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像坞古,于是被迫代替她去往敵國和親备韧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,647評論 2 354

推薦閱讀更多精彩內(nèi)容