您好,登錄后才能下訂單哦!
今天給大家介紹一下MyBatis resultMap id標簽的錯誤使用方式是什么。文章的內(nèi)容小編覺得不錯,現(xiàn)在給大家分享一下,覺得有需要的朋友可以了解一下,希望對大家有所幫助,下面跟著小編的思路一起來閱讀吧。
我們在編寫VO對象,如果業(yè)務(wù)場景稍微復雜一點,就會用到集合屬性。例如用戶查看個人訂單列表,每個訂單又包含多種或者多個規(guī)格的商品。
id是resultMap以及Collection的子標簽,標記出作為 ID 的結(jié)果可以幫助提高整體性能。特別注意的是,id是當前命名空間中的一個唯一標識,用于標識一個結(jié)果映射。
如下圖,itemId(商品id)字段值在數(shù)據(jù)庫中不唯一,錯誤使用會導致只返回該訂單某商品的一條記錄。因為對于某個商品,麻辣味和五香味只是商品規(guī)格,其商品id是相同的。
改用普通result標簽后,返回正確結(jié)果。
EOF
<!-- resultMap自定義某個javabean的封裝規(guī)則 type:自定義規(guī)則的java類型 id:唯一id方便引用 --> <resultMap type="entity.Employee" id="getEmpByIdMap"> <!-- id指定主鍵列的封裝規(guī)則 column:指定哪一列 property:指定對應(yīng)的javabean屬性 --> <id column="id" property="id"/> <!-- result定義普通列封裝規(guī)則,若屬性名與數(shù)據(jù)庫對應(yīng)表的列名相同可不寫, mybatis會自動封裝,但建議將所有的映射規(guī)則都寫上 --> <result column="name" property="name"/> <result column="sex" property="sex"/> <result column="email" property="email"/> </resultMap> <!-- public Employee getEmpById(Integer id) --> <select id="getEmpById" resultMap="getEmpByIdMap"> select * from employee where id=#{id} </select>
association
可以指定聯(lián)合的javabean對象
property="dept"
:指定哪個屬性是聯(lián)合對象
javaType
:指定這個屬性的類型
<resultMap type="entity.Employee" id="getEmpAndDeptMap"> <id column="id" property="id"/> <result column="empName" property="name"/> <result column="sex" property="sex"/> <result column="email" property="email"/> <!-- association可以指定聯(lián)合的javabean對象 property="dept":指定哪個屬性是聯(lián)合對象 javaType:指定這個屬性的類型--> <association property="dept" javaType="entity.Department"> <id column="did" property="id"/> <result column="deptName" property="departmentName"/> </association> </resultMap> <!-- public Employee getEmpAndDept(Integer id) --> <select id="getEmpAndDept" resultMap="getEmpAndDeptMap"> select e.id id,e.name empName,e.email email,e.sex sex,e.d_id d_id, d.id did,d.name deptName from employee e,dept d where e.d_id=d.id and e.id=#{id} </select>
1、先按照員工id查詢員工信息將會調(diào)用查詢員工的sql
2、根據(jù)查詢員工信息中的d_id值去部門表中查出部門信息
3、部門設(shè)置到員工中
<resultMap type="entity.Employee" id="getEmpAndDeptStepMap"> <id column="id" property="id"/> <result column="name" property="name"/> <result column="sex" property="sex"/> <result column="email" property="email"/> <!-- association定義關(guān)聯(lián)對象的封裝規(guī)則 select:表明當前屬性是調(diào)用select指定的方法查出的結(jié)果 column:指定將那一列的值作為參數(shù)傳給這個方法 流程:使用select指定的方法(傳入column指定的這列參數(shù)的值)查出對象, 并封裝給property指定的屬性 --> <!-- discriminator鑒別器 column:指定判定的列名 javaType:列值對應(yīng)的java類型 --> <discriminator javaType="string" column="sex"> <!-- resultType不能缺少 --> <case value="男" resultType="entity.Employee"> <association property="dept" select="dao.DepartmentMapper.getDeptById" column="d_id"> </association> </case> </discriminator> </resultMap> <!-- public Employee getEmpByIdStep(Integer id) --> <select id="getEmpByIdStep" resultMap="getEmpAndDeptStepMap"> select * from employee where id=#{id} </select>
嵌套結(jié)果集的方式,使用collection標簽定義關(guān)聯(lián)的集合類型的屬性封裝規(guī)則
<resultMap type="entity.Department" id="getDeptByIdPlusMap"> <id column="did" property="id"/> <result column="deptName" property="departmentName"/> <!-- collection定義關(guān)聯(lián)集合類型的屬性的封裝規(guī)則 ofType:指定集合里面元素的類型 --> <collection property="emps" ofType="entity.Employee"> <!-- 定義這個集合中元素的封裝規(guī)則 --> <id column="eid" property="id"/> <result column="empName" property="name"/> <result column="sex" property="sex"/> <result column="email" property="email"/> </collection> </resultMap> <!-- public Department getDeptByIdPlus(Integer id) --> <select id="getDeptByIdPlus" resultMap="getDeptByIdPlusMap"> select d.id did,d.name deptName,e.id eid, e.name empName,e.sex,e.email from dept d left join employee e on d.id=e.d_id where d.id=#{id} </select>
<resultMap type="entity.Department" id="getDeptByIdStepMap"> <id column="id" property="id"/> <result column="name" property="departmentName"/> <collection property="emps" select="dao.EmployeeMapperPlus.getEmpsByDeptId" column="{id}"> <!-- 或則 column="{deptId=id}"--> </collection> </resultMap> <!-- public List<Employee> getEmpsByDeptId(Integer deptId --> <select id="getEmpsByDeptId" resultType="entity.Employee"> select * from employee where d_id=#{deptId} </select> <!-- public Department getDeptByIdStep(Integer id) --> <select id="getDeptByIdStep" resultMap="getDeptByIdStepMap"> select * from dept where id=#{id} </select>
當分布查詢需要傳遞多個多個值時,將多個值封裝map傳遞
colum=“{key1=column1,key2=colum2...}”
以上就是MyBatis resultMap id標簽的錯誤使用方式是什么的全部內(nèi)容了,更多與MyBatis resultMap id標簽的錯誤使用方式是什么相關(guān)的內(nèi)容可以搜索億速云之前的文章或者瀏覽下面的文章進行學習哈!相信小編會給大家增添更多知識,希望大家能夠支持一下億速云!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。