spring+mybatis3套路訓(xùn)練:基本的增刪改查實(shí)現(xiàn)用戶rest api牍蜂,動(dòng)態(tài)SQL的構(gòu)建(注解形式)

上節(jié)課我們快速的整合了spring和mybatis,基于這些知識(shí)點(diǎn)我們進(jìn)行套路的訓(xùn)練
這節(jié)課我們學(xué)下動(dòng)態(tài)SQL創(chuàng)建和基本的增刪改查
上幾節(jié)課我們做了用戶的Controller(UsersController)我們上節(jié)課創(chuàng)建了個(gè)接口泰涂,里面寫(xiě)入了@Select注解(目前我們講的都是以注解的方式)后面我們會(huì)使用xml的方式鲫竞,這節(jié)課還是以注解的方式利用sql語(yǔ)句結(jié)合相關(guān)類來(lái)完成里面的功能
下面我們模擬下下面這些功能(做下面的小案例)

image.png

首先我們要實(shí)現(xiàn)訪問(wèn)GET/users 如果是這樣的路徑 則獲取用戶全部列表信息
GET/users/123 獲取用戶詳細(xì)信息 POST/users新增用戶 DELETE/users刪除用戶 PUT/users修改用戶
我們還是結(jié)合users_reg這張表做演示
首先我們把UserInfo實(shí)體類中私有屬性加入useremail字段 使其和數(shù)據(jù)庫(kù)表中的字段一致
image.png

下面我們就使用spring結(jié)合mybatis實(shí)現(xiàn)一個(gè)簡(jiǎn)單的用戶api
下面我們寫(xiě)下代碼
首先看下上節(jié)課的內(nèi)容
image.png

上節(jié)課我們?cè)赨serMapper接口中寫(xiě)了獲取用戶詳細(xì)信息的接口(根據(jù)用戶id)
這節(jié)課我們接著寫(xiě) 首先我們寫(xiě)獲取用戶全部列表接口
代碼如下
image.png

以上代碼為基本的增刪改查代碼
上面的代碼會(huì)有個(gè)問(wèn)題 如果我們想要執(zhí)行新增操作 可能要返回新增用戶id(在mysql中為自增id)這里我們會(huì)用到mybatis中的一個(gè)特性 叫selectkey
下面是selectkey的簡(jiǎn)單寫(xiě)法
image.png

其中幾個(gè)參數(shù)說(shuō)明如下
statement表示如果完成新增操作后,我們的自增id是如何寫(xiě)出來(lái)的(這里面是使用mysql的自增id)
keyProperty表示一旦取出來(lái)后 這個(gè)值(自增id值)放在對(duì)應(yīng)UserInfo的哪一個(gè)字段里面進(jìn)行映射
before:false表示@Selectkey這句話是在Insert語(yǔ)句執(zhí)行之前還是之后產(chǎn)生的(mysql是之后)
resultType代表@SelectKey返回值的類型
這部分在官方文檔的這部分有說(shuō)明http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html
只不過(guò)文檔中是以xml方式來(lái)配置(后面我們?cè)趯W(xué))
下面我們看下@SelectKey如何做以及如何映射
官方示例代碼如下(官方文檔搜索SelectKey)是以xml方式的示例
image.png

我們課程中暫時(shí)使用注解的方式返回新增用戶的id
在UserMapper中加入如下
image.png

接下來(lái)我們把剛才講的rest形式案例給實(shí)現(xiàn)了
image.png

在我們UsesController中寫(xiě)了最簡(jiǎn)單的getUserDetail(通過(guò)用戶id獲取用戶詳細(xì)信息)
下面我們?cè)诶锩嫣砑有碌姆椒?br> 因?yàn)槲覀儼咐杏性鰟h改查四個(gè)方法 所以我們要在spring配置文件中加入(GET,PUT,Delete逼蒙,Insert跨域請(qǐng)求方式)
添加如下
image.png

否則前端調(diào)用時(shí)可能存在問(wèn)題
下面我們回到UsersController中繼續(xù)寫(xiě)代碼
如下
image.png

image.png

寫(xiě)好代碼后我們編譯下代碼
使用火狐的插件測(cè)試下接口
get方式使用瀏覽器就可以測(cè)試
如下
image.png

訪問(wèn)localhost:8080/users
image.png

取出用戶所有列表
訪問(wèn)localhost:8080/users/3
image.png

返回用戶詳細(xì)信息
接下來(lái)測(cè)試下post put 和delete方式
新增用戶
image.png

header我們?cè)O(shè)置成application/json的格式
結(jié)果如下
image.png

再看下我們數(shù)據(jù)庫(kù)user_reg表
image.png

新增用戶成功
接下來(lái)測(cè)試修改用戶(PUT)就測(cè)試剛剛新增的userid為8的用戶
image.png

點(diǎn)擊send
結(jié)果如下
image.png

將user_name修改為zhad_new
看下數(shù)據(jù)庫(kù)表中結(jié)果
image.png

可以看見(jiàn)userid為8的用戶名變?yōu)閦had_new了
下面測(cè)試下刪除用戶操作
image.png

刪除用戶id為4的用戶
點(diǎn)擊send結(jié)果如下
image.png

數(shù)據(jù)庫(kù)表中如下
image.png

可以看見(jiàn)userid為4的用于刪除了
以上就是最簡(jiǎn)單的用戶rest api和mybatis增刪改查來(lái)完成一個(gè)rest api的形式
下面我們學(xué)下動(dòng)態(tài)SQL
image.png

官方地址如下
http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html
官方給我們的示例是以xml方式演示的 我們這節(jié)課依然使用注解的方式來(lái)實(shí)現(xiàn)
官方示例如下
image.png

可以看出動(dòng)態(tài)SQL就是在我們sql語(yǔ)句上加入if choose等條件語(yǔ)句
上面我們實(shí)現(xiàn)了查詢用戶所有列表的api
在UserMapper接口中打上了@Select注解 寫(xiě)入了sql語(yǔ)句
下面我們模擬一下以下需求(拼湊動(dòng)態(tài)SQL是很重要的)
比如我們之前訪問(wèn)localhost:8080/users 是訪問(wèn)用戶所有列表
有時(shí)候我們只要獲取用戶id在某范圍內(nèi)的(比如下面這個(gè)需求)
image.png

接下來(lái)我們寫(xiě)下代碼
有兩種寫(xiě)法
1从绘、字符串拼接方式(也就是跟官方很類似的寫(xiě)法 foreach寫(xiě)法)
官方示例如下
image.png

支持我們?cè)趨?shù)中傳入list 然后每一行就是item進(jìn)行循環(huán) index就是每次迭代的次數(shù)
首先我們?cè)赨serMapper中修改返回用戶列表接口
image.png

sql拼接時(shí)回行的話需要注解下一行前面要有空格 否則sql語(yǔ)句會(huì)報(bào)錯(cuò)
上面意思為循環(huán)傳入?yún)?shù)ids集合中的每一項(xiàng)
接下來(lái)在UsersController中修改如下
image.png

編譯發(fā)布下代碼
瀏覽器訪問(wèn)localhost:8080/users
結(jié)果如下
image.png

返回了用戶id為5和6的列表了
而我們數(shù)據(jù)庫(kù)表中數(shù)據(jù)如下
image.png

可以看出查詢出用戶id在某一范圍內(nèi)的用戶列表了
現(xiàn)在我們的參數(shù)是寫(xiě)死的 也就是說(shuō)我們必定會(huì)有一個(gè)list傳入 然后進(jìn)行sql語(yǔ)句的拼接
如果傳入是null或者空數(shù)組 那么這個(gè)sql語(yǔ)句就會(huì)報(bào)錯(cuò)
接下來(lái)我們?cè)赨sersController中在改下代碼
image.png

然后我們?cè)诨氐経serMapper接口中
其實(shí)上面在@Select注解中傳入的是一個(gè)String數(shù)組
所以還可以寫(xiě)成下面的格式 每行以逗號(hào)的形式 傳入數(shù)組 就不需要寫(xiě)很多加號(hào)進(jìn)行拼接
如下
image.png

因?yàn)槲覀円獙?duì)傳入?yún)?shù)做限制
所以還要改下sql語(yǔ)句
需要加入if語(yǔ)句
示例如下
image.png

我們代碼如下
image.png

接下來(lái)編譯下代碼
瀏覽器訪問(wèn)localhost:8080/users結(jié)果如下
image.png

沒(méi)傳參數(shù) 返回全部列表
傳入?yún)?shù)5,6返回如下
image.png

傳入?yún)?shù)3
image.png

以上就是我們學(xué)的動(dòng)態(tài)SQL配合我們的注解方式來(lái)搞定 下節(jié)課我們會(huì)使用xml配置文件方式來(lái)完成

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市是牢,隨后出現(xiàn)的幾起案子僵井,更是在濱河造成了極大的恐慌,老刑警劉巖驳棱,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件批什,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡社搅,警方通過(guò)查閱死者的電腦和手機(jī)驻债,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門乳规,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人合呐,你說(shuō)我怎么就攤上這事暮的。” “怎么了淌实?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵冻辩,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我翩伪,道長(zhǎng)微猖,這世上最難降的妖魔是什么谈息? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任缘屹,我火速辦了婚禮,結(jié)果婚禮上侠仇,老公的妹妹穿的比我還像新娘轻姿。我一直安慰自己,他們只是感情好逻炊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布互亮。 她就那樣靜靜地躺著,像睡著了一般余素。 火紅的嫁衣襯著肌膚如雪豹休。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天桨吊,我揣著相機(jī)與錄音威根,去河邊找鬼。 笑死视乐,一個(gè)胖子當(dāng)著我的面吹牛洛搀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播佑淀,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼留美,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了伸刃?” 一聲冷哼從身側(cè)響起谎砾,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎捧颅,沒(méi)想到半個(gè)月后景图,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡隘道,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年症歇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了郎笆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡忘晤,死狀恐怖宛蚓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情设塔,我是刑警寧澤凄吏,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站闰蛔,受9級(jí)特大地震影響痕钢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜序六,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一任连、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧例诀,春花似錦随抠、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至扔罪,卻和暖如春秉沼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背矿酵。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工唬复, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人坏瘩。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓盅抚,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親倔矾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子妄均,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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

  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL哪自、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥(niǎo)慢飛閱讀 5,510評(píng)論 0 4
  • 昨天打電話丰包,老家的侄女家又添了個(gè)老二。老大是兒子壤巷,全家喜笑顏開(kāi)邑彪,這老二,全家都盼著是個(gè)女兒胧华,結(jié)果又是兒子寄症。當(dāng)然也是...
    中年智慧閱讀 194評(píng)論 0 0
  • 公平的兩個(gè)不同起因: 第一宙彪,是人們生來(lái)就有對(duì)公平的偏好、追求有巧,這是人性的一部分释漆。 第二,是人們要追求效率篮迎。馬糞爭(zhēng)奪...
    爺有蔓草閱讀 568評(píng)論 0 0
  • 絲絲弦音男图,點(diǎn)點(diǎn)心情。 悠揚(yáng)的提琴聲甜橱,青草飄搖著的草原逊笆。 顫動(dòng)的鋼絲弦,向天長(zhǎng)鳴著的斑馬岂傲。 晃動(dòng)的馬尾弓难裆,被血染紅著...
    暮林西雨閱讀 258評(píng)論 0 1
  • 花道在中國(guó)也可稱為插花藝術(shù),其基本精神就是“天譬胎、地差牛、人”的和諧統(tǒng)一,這是東方特有的自然觀念和哲學(xué)觀念堰乔。9月6日,一...
    文化咖閱讀 623評(píng)論 0 0