詳解Mybatis模糊查詢和動(dòng)態(tài)sql語(yǔ)句的用法_第1頁(yè)
詳解Mybatis模糊查詢和動(dòng)態(tài)sql語(yǔ)句的用法_第2頁(yè)
詳解Mybatis模糊查詢和動(dòng)態(tài)sql語(yǔ)句的用法_第3頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、詳解Mybatis模糊查詢和動(dòng)態(tài)sql語(yǔ)句的用法Mybatis模糊查詢和動(dòng)態(tài)sql語(yǔ)句模糊查詢對(duì)數(shù)據(jù)庫(kù)最常用的操作就是查詢了,但是如何使用Mybatis進(jìn)行模糊查詢呢?下面先看一個(gè)簡(jiǎn)單的模糊查詢vselectid=selectO1resultMap=BasicResultMapSELECT*FROMoa_employeeWHEREemp_nameLIKE#asd這是一條偽模糊查詢,因?yàn)闆](méi)有實(shí)現(xiàn)真正的模糊“”。參數(shù)為字符串,所以#中內(nèi)容不被限制。但是應(yīng)該如何插入%字符呢。我們首先想到的是傳遞字符串參數(shù)時(shí)將插入到字符串中“張”,但是這種方法操作略微繁瑣了一些。下面提供了使用sql方法的策略SELE

2、CT*FROMoa_employeeWHEREemp_nameLIKECONCAT(#asd另外一種不推薦的寫(xiě)法給大家SELECT*FROMoa_employeeWHEREemp_nameLIKE$emp_name%他是在#表達(dá)式自動(dòng)填入value值,值得注意的是“_parameter.getEmp_name()調(diào)用的方法是對(duì)象中作為查詢參數(shù)的屬性的get方法多條件查詢多種條件查詢的要點(diǎn)是判斷查詢條件是否為空,拼接sql語(yǔ)句。在mybatis中提供了if標(biāo)簽和where標(biāo)簽。下面來(lái)介紹兩種標(biāo)簽的用法。f標(biāo)簽SELECT*FROMoa_employeeWHERE1=1andemp_name=#e

3、mp_nameandsex=#emp_sexmybatis中的if標(biāo)簽有些類似于EL表達(dá)式的使用,test中可以直接寫(xiě)入類中的屬性或者key值。where標(biāo)簽vselectid=selectO1resultMap=BasicResultMapSELECT*FROMoa_employeeandemp_name=#emp_nameandsex=#emp_sex這里的where標(biāo)簽替換了前一段代碼的where1=1。mybatis中的where標(biāo)簽會(huì)判斷標(biāo)簽內(nèi)是否有內(nèi)容,如果有內(nèi)容就自動(dòng)生成where并把where后面的第一個(gè)and+個(gè)空格,or+個(gè)空格去掉。choose,when和otherwis

4、e標(biāo)簽SELECT*FROMoa_employeeandemp_name=#emp_nameandsex=#emp_sexemp_id=50當(dāng)所有條件不滿足時(shí),執(zhí)行otherwise標(biāo)簽的內(nèi)容。trim標(biāo)簽SELECT*FROMoa_employeeandemp_name=#emp_nameandsex=#emp_sextrim標(biāo)簽的屬性及其含義“prefix:標(biāo)簽之間有內(nèi)容在最前面加入“prefixOverrides:檢查內(nèi)容的最前面是否匹配,匹配就刪除suffix:標(biāo)簽之間有內(nèi)容在最后面加入“suffixOverrides:檢查內(nèi)容的最后面是否匹配,匹配就刪除set標(biāo)簽set標(biāo)簽常用于up

5、date操作,并且會(huì)自動(dòng)抹掉無(wú)關(guān)的vupdateid=update01UPDATEoa_employeeemp_name=#emp_name,sex=#emp_sexWHEREemp_id=50Updateforeach標(biāo)簽foreach用于處理數(shù)組或者list集合,下面是一個(gè)批量添加的例子vinsertid=insert01INSERTINTOoa_employee(emp_name,sex,fk_dept_id)VALUESvforeachcollection=listitem=employeeseparator=,(#employee.emp_name,#employee.emp_sex,#employee.fk_dept_id)其中如果參數(shù)為數(shù)組貝Ucollection只能為“array參數(shù)為L(zhǎng)ist集合則collection只能為listitem類似JSTL中的var的作用,指代容器中的每一個(gè)對(duì)象。separator=,的含義是每條數(shù)據(jù)以,分割。未注明的屬性有open和close他們的含義是在遍歷開(kāi)始和結(jié)束時(shí)分別添加其內(nèi)容。DOJ果程引入舊二氏從】oijoiaJAVA石士施旦舊士二說(shuō)11【弓士三說(shuō)】制呂士丘俛】1M5法的UTJDEAH慈凋用,2士?jī)?cè)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論