溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用mybatis時(shí)字段無法映射成功如何解決

發(fā)布時(shí)間:2020-11-25 14:32:04 來源:億速云 閱讀:1085 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)使用mybatis時(shí)字段無法映射成功如何解決,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

mybatis中reultMap定義正確column與property也都正確,字段的getset方法也都有,但是返回對(duì)象時(shí),有些字段可以對(duì)應(yīng)上有一些則不可以。

找了好久才發(fā)現(xiàn)在sql語句中的 resultMap 寫成了 resultType。。。

很low但是痛。改成resultMap一切正常!

補(bǔ)充知識(shí):MyBatis學(xué)習(xí)總結(jié)——解決字段名與實(shí)體類屬性名不相同的沖突

在平時(shí)的開發(fā)中,我們表中的字段名和表對(duì)應(yīng)實(shí)體類的屬性名稱不一定都是完全相同的,下面來演示一下這種情況下的如何解決字段名與實(shí)體類屬性名不相同的沖突。

一、準(zhǔn)備演示需要使用的表和數(shù)據(jù)

CREATE TABLE orders(
 order_id INT PRIMARY KEY AUTO_INCREMENT,
 order_no VARCHAR(20), 
 order_price FLOAT
);
INSERT INTO orders(order_no, order_price) VALUES('aaaa', 23);
INSERT INTO orders(order_no, order_price) VALUES('bbbb', 33);
INSERT INTO orders(order_no, order_price) VALUES('cccc', 22);

二、定義實(shí)體類

package me.gacl.domain;

/**
 * @author gacl
 * 定義orders表對(duì)應(yīng)的實(shí)體類
 */
public class Order {
 /**
  * 
 CREATE TABLE orders(
  order_id INT PRIMARY KEY AUTO_INCREMENT,
  order_no VARCHAR(20), 
  order_price FLOAT
 );
 */
 
 //Order實(shí)體類中屬性名和orders表中的字段名是不一樣的
 private int id;    //id===>order_id
 private String orderNo;  //orderNo===>order_no
 private float price;  //price===>order_price

 public int getId() {
  return id;
 }

 public void setId(int id) {
  this.id = id;
 }

 public String getOrderNo() {
  return orderNo;
 }

 public void setOrderNo(String orderNo) {
  this.orderNo = orderNo;
 }

 public float getPrice() {
  return price;
 }

 public void setPrice(float price) {
  this.price = price;
 }

 @Override
 public String toString() {
  return "Order [id=" + id + ", orderNo=" + orderNo + ", price=" + price+ "]";
 }
}

三、編寫測試代碼

3.1、編寫SQL的xml映射文件  

1、創(chuàng)建一個(gè)orderMapper.xml文件,orderMapper.xml的內(nèi)容如下:

<&#63;xml version="1.0" encoding="UTF-8" &#63;>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 為這個(gè)mapper指定一個(gè)唯一的namespace,namespace的值習(xí)慣上設(shè)置成包名+sql映射文件名,這樣就能夠保證namespace的值是唯一的
例如namespace="me.gacl.mapping.orderMapper"就是me.gacl.mapping(包名)+orderMapper(orderMapper.xml文件去除后綴)
 -->
<mapper namespace="me.gacl.mapping.orderMapper">
 
 <!-- 
  根據(jù)id查詢得到一個(gè)order對(duì)象,使用這個(gè)查詢是查詢不到我們想要的結(jié)果的,
  這主要是因?yàn)閷?shí)體類的屬性名和數(shù)據(jù)庫的字段名對(duì)應(yīng)不上的原因,因此無法查詢出對(duì)應(yīng)的記錄
 -->
 <select id="getOrderById" parameterType="int" 
  resultType="me.gacl.domain.Order">
  select * from orders where order_id=#{id}
 </select>
 
 <!-- 
  根據(jù)id查詢得到一個(gè)order對(duì)象,使用這個(gè)查詢是可以正常查詢到我們想要的結(jié)果的,
  這是因?yàn)槲覀儗⒉樵兊淖侄蚊计鹨粋€(gè)和實(shí)體類屬性名相同的別名,這樣實(shí)體類的屬性名和查詢結(jié)果中的字段名就可以一一對(duì)應(yīng)上
 -->
 <select id="selectOrder" parameterType="int" 
  resultType="me.gacl.domain.Order">
  select order_id id, order_no orderNo,order_price price from orders where order_id=#{id}
 </select>
 
 <!-- 
 根據(jù)id查詢得到一個(gè)order對(duì)象,使用這個(gè)查詢是可以正常查詢到我們想要的結(jié)果的,
 這是因?yàn)槲覀兺ㄟ^<resultMap>映射實(shí)體類屬性名和表的字段名一一對(duì)應(yīng)關(guān)系 -->
 <select id="selectOrderResultMap" parameterType="int" resultMap="orderResultMap">
  select * from orders where order_id=#{id}
 </select>
 <!--通過<resultMap>映射實(shí)體類屬性名和表的字段名對(duì)應(yīng)關(guān)系 -->
 <resultMap type="me.gacl.domain.Order" id="orderResultMap">
  <!-- 用id屬性來映射主鍵字段 -->
  <id property="id" column="order_id"/>
  <!-- 用result屬性來映射非主鍵字段 -->
  <result property="orderNo" column="order_no"/>
  <result property="price" column="order_price"/>
 </resultMap>
 
</mapper>

2、在conf.xml文件中注冊orderMapper.xml映射文件

<mappers>  
  <!-- 注冊orderMapper.xml文件, 
  orderMapper.xml位于me.gacl.mapping這個(gè)包下,所以resource寫成me/gacl/mapping/orderMapper.xml-->
  <mapper resource="me/gacl/mapping/orderMapper.xml"/>
</mappers>

3.2、編寫單元測試代碼

package me.gacl.test;

import me.gacl.domain.Order;
import me.gacl.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

public class Test2 {
 
 @Test
 public void testGetOrderById(){
  SqlSession sqlSession = MyBatisUtil.getSqlSession();
  /**
  * 映射sql的標(biāo)識(shí)字符串,
  * me.gacl.mapping.orderMapper是orderMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
  * getOrderById是select標(biāo)簽的id屬性值,通過select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
  */
  String statement = "me.gacl.mapping.orderMapper.getOrderById";//映射sql的標(biāo)識(shí)字符串
  //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Order對(duì)象返回
  Order order = sqlSession.selectOne(statement,1);//查詢orders表中id為1的記錄
  //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
  sqlSession.close();
  System.out.println(order);//打印結(jié)果:null,也就是沒有查詢出相應(yīng)的記錄
 }
 
 @Test
 public void testGetOrderById2(){
  SqlSession sqlSession = MyBatisUtil.getSqlSession();
  /**
  * 映射sql的標(biāo)識(shí)字符串,
  * me.gacl.mapping.orderMapper是orderMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
  * selectOrder是select標(biāo)簽的id屬性值,通過select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
  */
  String statement = "me.gacl.mapping.orderMapper.selectOrder";//映射sql的標(biāo)識(shí)字符串
  //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Order對(duì)象返回
  Order order = sqlSession.selectOne(statement,1);//查詢orders表中id為1的記錄
  //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
  sqlSession.close();
  System.out.println(order);//打印結(jié)果:Order [id=1, orderNo=aaaa, price=23.0]
 }
 
 @Test
 public void testGetOrderById3(){
  SqlSession sqlSession = MyBatisUtil.getSqlSession();
  /**
  * 映射sql的標(biāo)識(shí)字符串,
  * me.gacl.mapping.orderMapper是orderMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
  * selectOrderResultMap是select標(biāo)簽的id屬性值,通過select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
  */
  String statement = "me.gacl.mapping.orderMapper.selectOrderResultMap";//映射sql的標(biāo)識(shí)字符串
  //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Order對(duì)象返回
  Order order = sqlSession.selectOne(statement,1);//查詢orders表中id為1的記錄
  //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
  sqlSession.close();
  System.out.println(order);//打印結(jié)果:Order [id=1, orderNo=aaaa, price=23.0]
 }
}

執(zhí)行單元測試的結(jié)果:

1、testGetOrderById方法執(zhí)行查詢后返回一個(gè)null。

2、testGetOrderById2方法和testGetOrderById3方法執(zhí)行查詢后可以正常得到想要的結(jié)果。

四、總結(jié)   

上面的測試代碼演示當(dāng)實(shí)體類中的屬性名和表中的字段名不一致時(shí),使用MyBatis進(jìn)行查詢操作時(shí)無法查詢出相應(yīng)的結(jié)果的問題以及針對(duì)問題采用的兩種辦法:

解決辦法一:

通過在查詢的sql語句中定義字段名的別名,讓字段名的別名和實(shí)體類的屬性名一致,這樣就可以表的字段名和實(shí)體類的屬性名一一對(duì)應(yīng)上了,這種方式是通過在sql語句中定義別名來解決字段名和屬性名的映射關(guān)系的。

解決辦法二:

通過<resultMap>來映射字段名和實(shí)體類屬性名的一一對(duì)應(yīng)關(guān)系。這種方式是使用MyBatis提供的解決方式來解決字段名和屬性名的映射關(guān)系的。

關(guān)于使用mybatis時(shí)字段無法映射成功如何解決就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI