您好,登錄后才能下訂單哦!
小編給大家分享一下MyBatis中resultType與resultMap的返回類型有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
public List<MyUser> selectMyUserByNameLike(String name);
<!-- resultType 集合內的元素類型 --> <select id="selectMyUserByNameLike" resultType="myUser" parameterType="string"> select * from myuser where name like #{name} </select>
測試方法
public static void main(String[] args) { SqlSession session = null; try { InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); session = sqlSessionFactory.openSession(); MyUserMapper mapper = session.getMapper(MyUserMapper.class); List<MyUser> myUsers = mapper.selectMyUserByNameLike("%a%"); System.out.println(myUsers); } catch (IOException e) { e.printStackTrace(); } finally { if (session != null) { session.close(); } } }
<!--public List<Map<String,Object>> getMyUser()--> <select id="getMyUser" resultType="map"> select * from myuser </select>
public Map<String,Object> selectMyUserById(Integer id);
<select id="selectMyUserById" resultType="map" parameterType="integer"> select * from myuser where id = #{id} </select>
// 指定 Map 的 Key 從記錄中的 id 列獲取 @MapKey("id") public Map<String,MyUser> selectMyUserByGtId(Integer id);
<!-- resultType Map 中 value 的類型 --> <select id="selectMyUserByGtId" resultType="myUser" parameterType="integer"> select * from myuser where id > #{id} </select>
關于自動映射封裝的配置
<settings> <!-- 自動映射有三種模式,NONE、PARTIAL、FULL。NONE 不啟用自動映射,PARTIAL 只對非嵌套的 resultMap 進行自動映射,FULL 表示對所有的 resultMap 都進行自動映射。默認為 PARTIAL --> <setting name="autoMappingBehavior" value="PARTIAL"/> <!-- 數據庫字段下劃線轉Bean字段的駝峰命名 --> <setting name="mapUnderscoreToCamelCase" value="true"/> <!-- 控制臺打印SQL --> <setting name="logImpl" value="STDOUT_LOGGING" /> </settings>
默認數據庫字段與 JavaBean 對應不上時可開啟駝峰命名或查詢時使用別名http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html
確認是否成功可以關掉 MyBatis 的自動映射
<setting name="autoMappingBehavior" value="NONE"/>
public MyUser selectMyUserById(Integer id);
<!-- 自定義某個 javaBean 的封裝規則 type:自定義規則中JavaBean類型的全路徑,可用別名 id:唯一id方便引用 --> <resultMap type="myUser" id="myUserResultMap"> <!-- 指定主鍵列的封裝規則,用 id 標簽定義主鍵會底層有優化 column:指定哪一列 property:指定對應的javaBean屬性 --> <id column="id" property="id"/> <!-- 定義普通列封裝規則 --> <result column="name" property="name"/> <!-- 其他不指定的列會自動封裝:建議只要寫 resultMap 就把全部的映射規則都寫上 --> <result column="age" property="age"/> </resultMap> <!-- 使用 resultMap,不使用 resultType --> <select id="selectMyUserById" resultMap="myUserResultMap" parameterType="integer"> select * from myuser where id = #{id} </select>
public MyUser selectMyUserById(Integer id);
直接調用屬性賦值
<resultMap type="myUser" id="myUserResultMap"> <id column="id" property="id"/> <result column="name" property="name"/> <result column="age" property="age"/> <!--直接屬性封裝--> <result column="did" property="dept.id"/> <result column="dname" property="dept.name"/> </resultMap> <select id="selectMyUserById" resultMap="myUserResultMap" parameterType="integer"> SELECT m.id, m.name, m.age, m.did, d.name AS dname FROM myuser m,dept d WHERE m.did = d.id AND m.id = #{id} </select>
使用association
<resultMap type="com.bean.MyUser" id="myUserResultMap"> <id column="id" property="id"/> <result column="name" property="name"/> <result column="age" property="age"/> <!-- association 指定聯合的 javaBean 對象 property="dept":指定哪個屬性是聯合的對象 javaType:指定這個屬性對象的類型[不能省略] --> <association property="dept" javaType="com.bean.Dept"> <id column="did" property="id"/> <result column="dname" property="name"/> </association> </resultMap> <select id="selectMyUserById" resultMap="myUserResultMap" parameterType="integer"> SELECT m.id, m.name, m.age, m.did, d.name AS dname FROM myuser m,dept d WHERE m.did = d.id AND m.id = #{id} </select>
使用association 二次查詢,即有兩條 SQL
<resultMap id="myUserResultMap" type="com.bean.MyUser"> <id column="id" property="id"/> <result column="name" property="name"/> <result column="age" property="age"/> <!-- association 定義關聯對象的封裝規則 select:當前屬性是調用 select 指定的方法查出的結果 column:將哪一列的值傳給這個方法 --> <association property="dept" select="com.dao.DeptMapper.selectDeptById" column="did"/> </resultMap> <select id="selectMyUserById" resultMap="myUserResultMap" parameterType="integer"> SELECT * FROM myuser WHERE id = #{id} </select>
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- namespace 對應接口文件的全路徑 --> <mapper namespace="com.dao.DeptMapper"> <select id="selectDeptById" resultType="dept" parameterType="string"> select * from dept where id = #{id} </select> </mapper>
開啟懶加載:在沒有使用 Dept 的屬性時,則只會加載 MyUser 的屬性。即只會發送一條 SQL 語句,要使用Dept 屬性時才會發送第二條 SQL。不會一次性發送兩條 SQL
<!-- 延遲加載的全局開關。當開啟時,所有關聯對象都會延遲加載。 特定關聯關系中可通過設置fetchType屬性來覆蓋該項的開關狀態。默認false --> <setting name="lazyLoadingEnabled" value="true"/> <!-- 當開啟時,任何方法的調用都會加載該對象的所有屬性。否則,每個屬性會按需加載。默認false (true in ≤3.4.1) --> <setting name="aggressiveLazyLoading" value="false"/>
使用association
public Dept getDeptById(Integer id);
<resultMap type="com.bean.Dept" id="MyDept"> <id column="did" property="id"/> <result column="dname" property="name"/> <!-- collection 定義關聯集合類型的屬性封裝規則 ofType 指定集合里面元素的類型 --> <collection property="myUsers" ofType="com.bean.MyUser"> <!-- 定義集合中元素的封裝規則 --> <id column="id" property="id"/> <result column="name" property="name"/> <result column="age" property="age"/> </collection> </resultMap> <select id="getDeptById" resultMap="MyDept"> SELECT m.id,m.name,m.age,m.did,d.name AS dname FROM myuser m,dept d WHERE m.did = d.id AND d.id = #{id} </select>
關閉懶加載,使用二次查詢
public Dept getDeptByIdStep(Integer did);
<!-- Collection 分段查詢 --> <resultMap type="com.bean.Dept" id="MyDeptStep"> <id column="id" property="id"/> <result column="name" property="name"/> <collection property="myUsers" select="com.dao.MyUserMapper.selectMyUserByDid" column="{did=id}" fetchType="eager"/> <!-- column 要處理復合主鍵或傳遞多個值過去:可以將多列的值封裝 Map 傳遞,指定多個列名通過 column="{prop1=col1,prop2=col2}" 語法來傳遞給嵌套查詢語句。這會引起 prop1 和 prop2 以參數對象形式來設置給目標嵌套查詢語句 fetchType="lazy":是否延遲加載,優先級高于全局配置,lazy:延遲,eager:立即 --> </resultMap> <select id="getDeptByIdStep" resultMap="MyDeptStep"> select * from dept where id = #{id} </select>
public List<MyUser> selectMyUserByDid(Integer dId);
<select id="selectMyUserByDid" resultType="myUser"> select * from myuser where dId = #{did} </select>
<!--public MyUser selectMyUserById(Integer id);--> <select id="selectMyUserById" resultMap="MyEmpDis" parameterType="integer"> SELECT * FROM myuser WHERE id = #{id} </select> <resultMap id="MyEmpDis" type="com.bean.MyUser"> <id column="id" property="id"/> <result column="name" property="name"/> <result column="age" property="age"/> <!-- column:指定判定的列名 javaType:列值對應的java類型 --> <discriminator javaType="integer" column="age"> <!-- 21歲 封裝課程至 JavaBean --> <case value="21" resultType="com.bean.MyUser"> <association property="dept" select="com.dao.DeptMapper.selectDeptById" column="did"/> </case> <!-- 33歲 不封裝課程至 JavaBean 且把 age 賦值給 id --> <case value="33" resultType="com.bean.MyUser"> <result column="age" property="id"/> </case> </discriminator> </resultMap>
<!--public Dept selectDeptById(Integer id);--> <select id="selectDeptById" resultType="dept" parameterType="string"> select * from dept where id = #{id} </select>
上面測試中使用的實體類與數據
public class Dept { private Integer id; private String name; private List<MyUser> myUsers; public class MyUser { private Integer id; private String name; private Integer age; private Dept dept;
以上是“MyBatis中resultType與resultMap的返回類型有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。