亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis簡單resultMap使用詳解

 更新時間:2021年04月27日 09:00:36   作者:Splay_Tree  
resultMap是Mybatis最強大的元素,它可以將查詢到的復(fù)雜數(shù)據(jù)(比如查詢到幾個表中數(shù)據(jù))映射到一個結(jié)果集當中。這篇文章主要介紹了mybatis簡單resultMap使用詳解的相關(guān)資料,需要的朋友可以參考下

Mybatis的介紹以及使用:http://www.mybatis.org/mybatis-3/zh/index.html

mybatis是一個半自動的ORM(Object Relational Mapping)框架,需要手動配置一些SQL語句或者注解,相對來說Mybatis留給程序員操作的空間靈活度更高,通常需要手動配置一些東西完成OR映射。當數(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>			<!-- 使用日志進行幫忙查看 -->
        <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空值。使用輸出日志進行幫忙很容易看到區(qū)別。

在這里插入圖片描述

簡單的解決方案:就是SQL語句查詢時給查詢字段使用重命名。

select id, name as username, pwd as password from user

在這里插入圖片描述

2. resultMap解決屬性 - 字段不匹配問題

上面這種解決方案是能夠解決問題的,但是有點冗余本身就要查全部的信息用的 * 做通配。這么一改需要每個字段都列出來,然后對極個別的字段進行取別名。試想一下當數(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可以認為是定義方法名,整個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標簽的解釋:

  1. id可以認為定義方法的名稱,下面select中的resultMap傳入id的值就相當于使用這個方法完成映射。
  2. type是實體類名
  3. column對應(yīng)數(shù)據(jù)庫中的字段
  4. property是實體類的屬性。

到此這篇關(guān)于mybatis簡單resultMap使用詳解的文章就介紹到這了,更多相關(guān)mybatis resultMap使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JAVA隨機數(shù)隨機字母的實現(xiàn)(微信搶紅包小練習)

    JAVA隨機數(shù)隨機字母的實現(xiàn)(微信搶紅包小練習)

    這篇文章主要介紹了JAVA隨機數(shù)隨機字母的實現(xiàn)(微信搶紅包小練習),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • Java GUI插入圖片不顯示問題解決方法

    Java GUI插入圖片不顯示問題解決方法

    大家好,本篇文章主要講的是Java GUI插入圖片不顯示問題解決方法,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • 一文搞懂Java中的抽象類和接口到底是什么

    一文搞懂Java中的抽象類和接口到底是什么

    在類中沒有包含足夠的信息來描繪一個具體的對象,這樣的類稱為抽象類,接口是Java中最重要的概念之一,它可以被理解為一種特殊的類,不同的是接口的成員沒有執(zhí)行體,是由全局常量和公共的抽象方法所組成,本文給大家介紹Java抽象類和接口,感興趣的朋友一起看看吧
    2022-04-04
  • Spring aop 如何通過獲取代理對象實現(xiàn)事務(wù)切換

    Spring aop 如何通過獲取代理對象實現(xiàn)事務(wù)切換

    這篇文章主要介紹了Spring aop 如何通過獲取代理對象實現(xiàn)事務(wù)切換的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • SpringBoot的依賴管理配置

    SpringBoot的依賴管理配置

    一般來講SpringBoot項目是不需要指定版本,而SSM項目是需要指定版本,SpringBoot的核心依賴就是spring-boot-starter-parent和spring-boot-starter-web兩個依賴,關(guān)于這兩個依賴的相關(guān)介紹具體今天小編給大家介紹下
    2022-07-07
  • Java 動態(tài)加載jar和class文件實例解析

    Java 動態(tài)加載jar和class文件實例解析

    這篇文章主要介紹了Java 動態(tài)加載jar和class文件實例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • 剖析Java中在Collection集合中使用contains和remove為什么要重寫equals

    剖析Java中在Collection集合中使用contains和remove為什么要重寫equals

    這篇文章主要介紹了Collection集合的contains和remove方法詳解remove以及相關(guān)的經(jīng)驗技巧,通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • spring mvc高級技術(shù)實例詳解

    spring mvc高級技術(shù)實例詳解

    前面學習了簡單的Spring Web知識,接著學習更高階的Web技術(shù)。下面這篇文章主要給大家介紹了spring mvc高級技術(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起看看吧
    2018-09-09
  • Java之判斷2000~2023年有哪些年份是閏年并打印輸出

    Java之判斷2000~2023年有哪些年份是閏年并打印輸出

    這篇文章主要介紹了Java之判斷2000~2023年有哪些年份是閏年并打印輸出,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java中volatile關(guān)鍵字的線程的可見性、有序性詳解

    Java中volatile關(guān)鍵字的線程的可見性、有序性詳解

    這篇文章主要介紹了Java中volatile關(guān)鍵字的線程的可見性、有序性詳解,在juc多線程并發(fā)編程中,常常需要關(guān)注線程的"可見性"與"有序性",本文將詳細介紹這兩部分內(nèi)容,以及volatile關(guān)鍵字的使用,需要的朋友可以參考下
    2024-01-01

最新評論