Mybatis參數傳遞及返回類型

mybatis參數傳遞:


?? ?單個參數:不做特殊處理
?? ??? ?#{參數名}:取出參數值
?? ?多個參數:做特殊處理
?? ??? ?多個參數會被封裝成一個map
?? ??? ??? ?key:param1?? ...?? paramN
?? ??? ??? ?value:傳入的參數值
?? ??? ?#{}就是從map中獲取指定的key值
?? ??? ?
?? ??? ?操作:
?? ??? ??? ?方法:public Employee getEmployeeByNmaeAndPass(String name,String pass);
?? ??? ??? ?取值:#{name},#{pass}

?? ?命名參數:明確指定封裝參數時map的key:@Param("id")
?? ??? ?多個參數會被封裝成一個map
?? ??? ??? ?key:使用@Param注解指定的值
?? ??? ??? ?value:參數值
?? ??? ??? ?#{指定的key}取出對應的參數值

?? ?POJO:

?? ?如果多個參數是業務模型中的數據,可以直接使用POJO:
?? ??? ??? ?#{屬性名}:取出傳入的POJO 的屬性值


?? ?Map:

?? ?如果多個參數不是業務模型中的數據,沒有對應的POJO,為了方便,可以傳入map
?? ??? ??? ?#{key}:取出map中對應的值

?? ?
?? ?TO:
?? ?如果多個參數不是業務模型中的數據,但是經常要是用,推薦來編寫一個TO(Transfer Object)數據傳輸對象
?? ?Page{
?? ??? ?int index;
?? ??? ?int size;
?? ?}

示例:

1、public Employee getEmployee(@Param("name")String name,String pass);
?? ?取值:name=====>#{name/param1}?? pass=====>#{param2}

2、public Employee getEmployee(String name,@Param("emp")Employee employee);
?? ?取值:name====>#{param1}????? pass=====>#{emp.pass/param2.pass}

3、如果是Collection(List?? Set)類型或者是數組型,也會特殊處理,
?? ?也是把傳入的list或者數組封裝在map中
?? ??? ?key:Collection(collection),如果是List還可以使用這個key(list)
?? ??? ????? 數組(array)
?? ?public Employee getEmpById(List<Integer> ids);
?? ?取值:取出第一個id的值:#{list[0]}


mybatis處理參數:
總結:參數多時會封裝map,未了不混亂,可以使用@Param來指定封裝時使用的key;
#{key}就可以取出map中的值

(@Param("id")Integer id,@Param("name")String name);
ParamNameResolver解析參數封裝的map:
?? ?names:{0=id,1=name}
?? ?1、獲取每個標了param注解的參數的@Param的值:id,name:賦值給name
?? ?2、每次解析一個參數給map中保存信息:(key:參數索引,value:name的值)
?? ??? ?name的值:
?? ??? ??? ?標注了param注解:注解值
?? ??? ??? ?沒有標注:
?? ??? ??? ?1、全局配置:userActualParam(jdk1.8):name=參數名
?? ??? ??? ?2、name=map.size();相當于當前元素索引

mybatis參數值的獲取
#{}:可以獲取map中的值或者pojo對象屬性的值
${}: 可以獲取map中的值或者pojo對象屬性的值
區別:
?? ?#{}:是以預編譯的形式,將參數設置到sql語句中:PreparedStatement;防止sql注入
?? ?${}:取出的值,直接拼接在sql語句中,會由安全問題;
?? ?大多情況下,都會使用#{}
?? ?當存在分表、排序:按照年份分表拆分
?? ??? ?原生jdbc不支持占位符的地方就可以使用${}進行取值
?? ??? ?select * from? ${year}_salary where xxxx;
?? ??? ?select * from tb_student order by ${name}
?? ??? ?
#{}:
?? ?可以規定參數的一些規則:
?? ?JavaType、jdbcType、mode(存儲過程)、numeriScale、resultMap、typeHandler、jdbcTypeName

?? ?jdbcType通常需要在某種特定的條件下唄被設置:
?? ??? ?在數據為null的時候,有些數據庫可能不能識別mybatis對null的默認處理。
?? ??? ?比如:Oracle(報錯)
?? ??? ?insert into student(id,name,age) values(null,'test',null)
?? ??? ?oracle不能識別對null的操作,報錯。因為mybatis對所有的null都映射的是原生jdbc的other類型。
?? ??? ?但是MySQL可以識別對null的操作,若想解決此問題,則使用以下添加語句;
?? ??? ?
?? ??? ?1、insert into student(id,name,age) values(#{id},#{name},#{age,jdbcType=NULL})
?? ?
?? ??? ?2、由于全局配置中,jdbcTypeForNull=OTHER:oracle不支持
?? ??? ??? ?<setting name="jdbcTypeForNull" value="NULL">
?? ??? ??? ?此配置對使用MySQL數據庫時的影響。

返回參數類型:
List型:
?? ?resultType:返回的是一個集合,要寫集合中元素的類型

Map型:
?? ?resultType=“map”:返回一條記錄
?? ?key:就是列名??? value:對應的值
?? ?mybatis對用到的部分類進行了封裝,可直接使用封裝類型。

?? ?返回多條記錄封裝一個map:
?? ?1、resultType:要寫集合中元素的類型。
?? ??? ?Map<Integer,Employee>:
?? ??? ??? ??? ?鍵是這條記錄的主鍵,值是記錄封裝后的JavaBean
?? ?2、在對應的方法上添加@MapKey("id") 告訴mybatis封裝這個map的時候使用哪個屬性作為map的key
???

轉載于:https://www.cnblogs.com/staticking/p/7001091.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/371971.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/371971.shtml
英文地址,請注明出處:http://en.pswp.cn/news/371971.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

網絡html代碼是什么問題,html代碼問題

html代碼問題來源:互聯網 2010-03-22 10:35:57 評論分類: 電腦/網絡 >> 程序設計 >> 其他編程語言問題描述:這三種鏈接格式我都試了&#xff0c;都不行&#xff0c;請高手指點下。。。。。注意&#xff1a;我要的是代碼&#xff0c;不是操作方法&#xff0c;因為…

spring mvc 文件上傳

spring mvc 文件上傳 一、單文件上傳 配置步驟&#xff1a; 步驟一、在配置文件中配置包掃描器&#xff08;暫且這樣配&#xff0c;會出問題&#xff0c;我們下面說解決方案&#xff09; <?xml version"1.0" encoding"UTF-8"?> <beans xmlns…

使用工廠模式解決設計問題

工廠設計模式是面向對象環境中最常用的模式之一。 再次來自“創意設計”模式類別&#xff0c;即有關對象創建的所有信息。 在某些情況下&#xff0c;對象的創建很復雜&#xff0c;可能需要某種程度的抽象&#xff0c;以便客戶端代碼無法意識到這些復雜性和內部實現細節。 在某些…

103. Binary Tree Zigzag Level Order Traversal

二刷。 BFS&#xff0c;基本習慣上用Iterative的做法來做&#xff0c;就是QUEUE。 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val x; }* }*/ public class Solution…

java多線程系列13 設計模式 Future 模式

Future 模式 類似于ajax請求 頁面異步的進行后臺請求 用戶無需等待請求的結果 就可以繼續瀏覽或者操作 核心就是&#xff1a;去除了主函數的等待時間&#xff0c;并使得原本需要等待的時間段可以用于處理其他業務邏輯 JDK內置實現Future模式演示一下 public class RealData im…

lodop轉到其他html頁面,Lodop實現打印功能

思路&#xff1a;1、在 html 頁面引入 LodopFuncs.js 文件&#xff0c;并用 object 標簽和 embed 標簽獲取 lodop 對象2、在 js 中獲取 html 頁面中的 object 和 embed 對象&#xff0c;并使用getLodop() 方法得到 lodop 對象3、實現打印功能&#xff0c;以下三步是必需的初始化…

完整的Web應用程序Tomcat JSF Primefaces JPA Hibernate –第3部分

Primefaces AutoComplete&#xff0c;JSF轉換器 這篇文章從第一部分和第二部分繼續。 JSF擁有Converter工具&#xff0c;可以幫助我們從用戶視圖中獲取一些數據并將其轉換為從數據庫或緩存中加載的對象。 在“ com.converter”包中&#xff0c;創建以下類&#xff1a; packa…

html5首屏加載樂山暴雨,發布前端項目時因chunk-vendors過大導致首屏加載太慢,Vue Build時chunk-vendors的優化方案...

這個優化是兩方面的&#xff0c;前端將文件打包成.gz文件&#xff0c;然后通過nginx的配置&#xff0c;讓瀏覽器直接解析.gz文件。1、compression-webpack-plugin插件打包.gz文件安裝插件npm install --save-dev compression-webpack-plugin或者yarn add compression-webpack-p…

width:100vh與min-height:calc(100vh + 51px)

vh:相對于視窗的高度&#xff0c;那么vw:則是相對于視窗的高度。 “視區”所指為瀏覽器內部的可視區域大小&#xff0c;即window.innerWidth/window.innerHeight大小&#xff0c;不包含任務欄標題欄以及底部工具欄的瀏覽器區域大小。 詳細vh的用法&#xff0c;大家可以參考http…

XML配置文件中的Spring配置文件

我的上一個博客非常簡單&#xff0c;因為它涵蓋了我從Spring 3.0.x到Spring 3.1.x的輕松升級&#xff0c;最后我提到可以將Spring模式升級到3.1&#xff0c;以利用Spring的最新功能。 在今天的博客中&#xff0c;我將介紹這些功能中最酷的功能之一&#xff1a;Spring配置文件。…

交大計算機專業怎樣,計算機專業高校實力排名,上海交大第五,清華第二,第一毫無爭議...

原標題&#xff1a;計算機專業高校實力排名&#xff0c;上海交大第五&#xff0c;清華第二&#xff0c;第一毫無爭議計算機專業在近幾年可謂是“大熱”&#xff0c;眾多考生搶破頭也想當碼農&#xff0c;背后的原因其實不難理解。互聯網時代的到來&#xff0c;計算機早已滲透到…

python_day7 綁定方法與非綁定方法

在類中定義函數如果 不加裝飾器 則默認 為對象作為綁定方法 如果增加 classmethod 是 以 類 作為綁定方法 增加 classmethod 是 非綁定方法&#xff0c;就是不將函數 綁定 ##################### class Foo: def func(self): print(self) classmethod def func…

Spring Security使用Hibernate實現自定義UserDetails

大多數時候&#xff0c;我們將需要在Web應用程序中配置自己的安全訪問角色。 這在Spring Security中很容易實現。 在本文中&#xff0c;我們將看到最簡單的方法。 首先&#xff0c;我們將在數據庫中需要以下表格&#xff1a; CREATE TABLE IF NOT EXISTS mydb.security_role (…

python之路-面向對象

編程范式 編程是 程序 員 用特定的語法數據結構算法組成的代碼來告訴計算機如何執行任務的過程 &#xff0c; 一個程序是程序員為了得到一個任務結果而編寫的一組指令的集合&#xff0c;正所謂條條大路通羅馬&#xff0c;實現一個任務的方式有很多種不同的方式&#xff0c; 對這…

西安郵電大學計算機科學與技術有專碩嗎,2020年西安郵電大學計算機學院考研擬錄取名單及排名!...

20考研復試調劑群&#xff1a;4197552812020年西安郵電大學計算機學院碩士研究生招生復試成績及綜合排名各位考生&#xff1a;現將我院2020年碩士研究生招生復試成績及綜合排名公布(最終錄取名單及新生學籍注冊均以“全國碩士研究生招生信息公開平臺”備案信息為準)&#xff0c…

用Java排序的五種有用方法

Java排序快速概述&#xff1a; 正常的列表&#xff1a; private static List VEGETABLES Arrays.asList("apple", "cocumbers", "blackberry");Collections.sort(VEGETABLES);output: apple, blackberry, cocumbers反向排序&#xff1a; pri…

[python]-數據科學庫Numpy學習

一、Numpy簡介&#xff1a; Python中用列表(list)保存一組值&#xff0c;可以用來當作數組使用&#xff0c;不過由于列表的元素可以是任何對象&#xff0c;因此列表中所保存的是對象的指針。這樣為了保存一個簡單的[1,2,3]&#xff0c;需要有3個指針和三個整數對象。對于數值運…

檢測一個點, 是否在一個半圓之內的方法

demo: http://jsbin.com/lihiwigaso 需求: 一個圓分成分部分, 鼠標滑上不同的區域顯示不同的顏色 思路: 先判斷這個點是否在圓之內, 再判斷是否在所在的三角形之內就可以了 所需要的全部源碼: <!DOCTYPE html> <html> <head><meta charset"utf-8&quo…

計算機網絡設備接地規范,網絡機房防雷接地的四種方式及靜電要求

編輯----河南新時代防雷由于計算機網絡系統的核心設備都放置在網絡機房內&#xff0c;因而網絡機房防雷接地有了較高的環境要求&#xff0c;良好的接地系統是保證機房計算機及網絡設備安全運行&#xff0c;以及工作人員人身安全的重要措施。直流地的接法通常采用網格地&#xf…

抓住尾部的StackOverFlowError

使用Java程序時可能要處理的一種更煩人的情況是StackOverFlowError&#xff0c;如果您有一個很好的可生產的測試用例&#xff0c;那么關于使用堆棧大小或設置條件斷點/某種痕跡 。 但是&#xff0c;如果您有一個測試案例可能一次失敗100次&#xff0c;或者像我的案例一樣在AWTM…