mybatis簡單resultMap使用詳解
Mybatis的介紹以及使用:http://www.mybatis.org/mybatis-3/zh/index.html
mybatis是一個半自動的ORM(Object Relational Mapping)框架,需要手動配置一些SQL語句或者注解,相對來說Mybatis留給程序員操作的空間靈活度更高,通常需要手動配置一些東西完成OR映射。當(dāng)數(shù)據(jù)庫表中的字段 和 POJO實體類不匹配時,這是就需要程序員手動完成字段的映射。
mybatis-config.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="db.properties"/>
<settings> <!-- 使用日志進(jìn)行幫忙查看 -->
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
<typeAliases> <!-- 取個別名 -->
<typeAlias type="com.pojo.User" alias="user"/>
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/dao/UserMapper.xml"/>
</mappers>
</configuration>
mybatisUtil加載工具類
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;
public class mybatisUtil {
private static SqlSessionFactory sqlSessionFactory = null;
static {
try {
String resource = "mybatis-config.xml";
InputStream in = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
}
public static SqlSession getSqlsession(){
return sqlSessionFactory.openSession();
}
}
POJO實體類User,為了方便簡單實用Lombok注解,減少一些代碼。

package com.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data //各種get / set方法 Tostring...
@AllArgsConstructor //全參構(gòu)造
@NoArgsConstructor //無參構(gòu)造
public class User {
private int id; //對應(yīng)數(shù)據(jù)庫中的id
private String username; //對應(yīng)數(shù)據(jù)庫中的name
private String password; //對應(yīng)數(shù)據(jù)庫中的pwd
}
接口方法與對應(yīng)的xml配置文件
package com.dao;
import com.pojo.User;
import java.util.List;
public interface UserMapper {
List<User> getUserList();
}
xml映射
<?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">
<mapper namespace="com.dao.UserMapper">
<select id="getUserList" resultType="user">
select *from user;
</select>
</mapper>
1. POJO實體類 和 數(shù)據(jù)表字段不匹配
@Test
public void test1(){
SqlSession session = mybatisUtil.getSqlsession();
UserMapper mapper = session.getMapper(UserMapper.class);
List<User> list = mapper.getUserList();
for (User user : list) {
System.out.println(user.toString());
}
session.close();
}
POJO實體類中有兩個字段和數(shù)據(jù)庫的字段不匹配,最后獲得結(jié)果的時對于匹配失敗的屬性會產(chǎn)生null空值。使用輸出日志進(jìn)行幫忙很容易看到區(qū)別。

簡單的解決方案:就是SQL語句查詢時給查詢字段使用重命名。
select id, name as username, pwd as password from user

2. resultMap解決屬性 - 字段不匹配問題
上面這種解決方案是能夠解決問題的,但是有點冗余本身就要查全部的信息用的 * 做通配。這么一改需要每個字段都列出來,然后對極個別的字段進(jìn)行取別名。試想一下當(dāng)數(shù)據(jù)表中有幾十個字段呢?而真正需要取別名的字段只有1 - 2個呢?因此mybatis提供了一個強大的機制resultMap結(jié)果集映射來解決這個問題。
<?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">
<mapper namespace="com.dao.UserMapper">
<!--
1. id可以認(rèn)為是定義方法名,整個resultMap是一個映射方法,調(diào)用這個方法就可以完成這個映射。
2. type是實體類的名稱
-->
<resultMap id="FieldMap" type="user">
<!-- column 是數(shù)據(jù)庫字段名 property是實體類屬性名 -->
<result column="name" property="username"/>
<result column="pwd" property="password"/>
</resultMap>
<select id="getUserList" resultMap="FieldMap">
select *from user
</select>
</mapper>

resultMap標(biāo)簽的解釋:
- id可以認(rèn)為定義方法的名稱,下面select中的resultMap傳入id的值就相當(dāng)于使用這個方法完成映射。
- type是實體類名
- column對應(yīng)數(shù)據(jù)庫中的字段
- property是實體類的屬性。
到此這篇關(guān)于mybatis簡單resultMap使用詳解的文章就介紹到這了,更多相關(guān)mybatis resultMap使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot啟動加載CommandLineRunner @PostConstruct問題
這篇文章主要介紹了springboot啟動加載CommandLineRunner @PostConstruct問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Jenkins如何使用DockerFile自動部署Java項目
這篇文章主要介紹了Jenkins如何使用DockerFile自動部署Java項目,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
SpringBoot異步調(diào)用方法實現(xiàn)場景代碼實例
這篇文章主要介紹了SpringBoot異步調(diào)用方法實現(xiàn)場景代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
解決SpringBoot加載application.properties配置文件的坑
這篇文章主要介紹了SpringBoot加載application.properties配置文件的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08

