欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis Mapper的xml文件中resultType值的使用說明

 更新時(shí)間:2021年10月09日 15:14:23   作者:Bonyin  
這篇文章主要介紹了mybatis Mapper的xml文件中resultType值的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mapper的xml文件中resultType值

①返回一般數(shù)據(jù)類型的值

比如根據(jù)id或者字段條件查詢獲取表中的某一個(gè)字段值

User Sel(int id); //根據(jù)id查詢

SQL映射文件

<select id="Sel" resultType="java.lang.String"> //注意這個(gè)寫了類全名 
    select username from user_test where id = #{id}
</select>  

如果需要簡(jiǎn)寫的話 需要定義resultType的別名

java 的基本類型不需要?jiǎng)e名的:

別名 映射的類型
_byte byte
_long long
_short short
_int int
_boolean boolean
integer Integer
string String
date Date
boolean Boolean

②當(dāng)返回類型是javaBean

<select id="Sel" resultType="com.tx.springboottestdemo.entity.User">
    select * from user_test where id = #{id}
</select>
<typeAliases>  
<!-- 針對(duì)單個(gè)別名定義 type:類型的路徑 alias:別名 -->  
<typeAlias type="cn.itcast.mybatis.po.User" alias="user"/>  

③當(dāng)返回是List類型

有時(shí)候我們需要模糊查詢或者是全表查詢,返回的數(shù)據(jù)是多條的, 那么可以把多條數(shù)據(jù)保存到list里面的。

mapper 接口

List<User> getUsers();

SQL映射文件:

<select id="getUsers" resultType="com.tx.entity.User">
select * from user
</select>

這里需要注意的是返回是List類型 但是resultType依然是javaBean, 有些人會(huì)困惑這里怎么不是集合類型呢?其實(shí)透過現(xiàn)象看本質(zhì), 還是JavaBean。

④返回類型數(shù)Map結(jié)構(gòu)

當(dāng)我們?cè)诓樵兊臅r(shí)候返回一條數(shù)據(jù)的時(shí)候,我們可以把{字段名,字段值}封裝成Map結(jié)構(gòu)。

Map<String, Object> findUserByName(Integer id);

SQL 映射文件:

<select id="findUserByName" resultType="string">
select userName from user where id=#{id};
</select>

⑤說一下關(guān)于mybatis里面mapper層中傳入多個(gè)參數(shù)的方法

1.其實(shí)可以看成是多個(gè)參數(shù)的

public List<User> findUser( String name1,  String name2);

對(duì)應(yīng)的SQL映射文件:

<select id="findUser3"  resultType="com.tx.springboottestdemo.entity.User">
    select * from user_test where userName = #{0} and realName = #{1}
</select> 

其中里面#{0}, #{1}默認(rèn)是按照mybatis傳值的順序位置索引的 但是在springboot2.1(集成mybatis框架)里面會(huì)報(bào)錯(cuò),我看網(wǎng)上說是可以的 我嘗試很多好像不行,下面貼出error:

~~org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter '0' not found. Available parameters are [arg1, arg0, param1, param2]~~

2.可以看做是加了注解

public List<User> findUser( @Param("name1") String name1, @Param("name2") String name2);

對(duì)應(yīng)的SQL文件:

<select id="findUser" resultType="com.tx.springboottestdemo.entity.User">
    select * from user_test where userName = #{name1} and realName = #{name2}
</select>

3.可以把參數(shù)封裝到Map里面

有些時(shí)候我們的業(yè)務(wù)數(shù)據(jù)查詢沒有定義對(duì)應(yīng)的POJO,就進(jìn)行參數(shù)的封裝操作。

public List<User> findUser1(Map<String, Object> map);

對(duì)應(yīng)的SQL文件:

<select id="findUser1" parameterType="java.util.Map" resultType="com.tx.springboottestdemo.entity.User">
    select * from user_test where userName = #{username} and realName = #{realname}
</select>

mybatis學(xué)習(xí)之resultType解析

resultType是sql映射文件中定義返回值類型,返回值有基本類型,對(duì)象類型,List類型,Map類型等?,F(xiàn)總結(jié)一下再解釋

總結(jié)

resultType:

1、基本類型:resultType=基本類型

2、List類型:resultType=List中元素的類型

3、Map類型:

單條記錄:resultType =map

多條記錄:resultType =Map中value的類型

1、對(duì)象類型

對(duì)于對(duì)象類型resultType直接寫對(duì)象的全類名就可以了

實(shí)例:

hotelMapper接口

package com.pjf.mybatis.dao;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    //返回值類型為Hotel
    public Hotel getHotel(Integer i);
}

HotelMapper.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.pjf.mybatis.dao.HotelMapper">
    <!--resultType直接寫對(duì)象的全類名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        id=#{id}
    </select>
</mapper>

測(cè)試類:

package com.pjf.mybatis;
import java.io.IOException;
import java.io.InputStream;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 org.junit.Test;
import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel;
public class TestHotel {
    public SqlSessionFactory sqlSessionFactory() throws IOException {
        // mybatis的配置文件
        String resource = "mybatis_config.xml";
        // 使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
        return sessionFactory;
    }
    // 查
    @Test
    public void getHotel() throws IOException {
        SqlSessionFactory sessionFactory = sqlSessionFactory();
        SqlSession session = sessionFactory.openSession();
        HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
        System.out.println(hotelMapper.getClass());
        //直接返回Hotel對(duì)象,打印出來        
        Hotel hotel = hotelMapper.getHotel(1001);
        System.out.println(hotel);
        session.close();
    }
}

2、List類型

返回值為L(zhǎng)ist類型,resultType為L(zhǎng)ist中對(duì)象的類型,如List<Hotel>,resultType為Hotel

實(shí)例:

hotelMapper接口

package com.pjf.mybatis.dao;
import java.util.List;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    // 返回值為L(zhǎng)ist
    public List<Hotel> getHotel(Integer i);
}

hotelMapper.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.pjf.mybatis.dao.HotelMapper">
    <!-- 返回值為L(zhǎng)ist,resultType為L(zhǎng)ist中元素的全類名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

測(cè)試類:

package com.pjf.mybatis;
import java.io.IOException;
import java.io.InputStream;
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 org.junit.Test;
import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel;
public class TestHotel {
    public SqlSessionFactory sqlSessionFactory() throws IOException {
        // mybatis的配置文件
        String resource = "mybatis_config.xml";
        // 使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
        return sessionFactory;
    }
    // 查
    @Test
    public void getHotel() throws IOException {
        SqlSessionFactory sessionFactory = sqlSessionFactory();
        SqlSession session = sessionFactory.openSession();
        HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
        System.out.println(hotelMapper.getClass());
        // 返回值為L(zhǎng)ist
        List<Hotel> list = hotelMapper.getHotel(1000);
        for (Hotel hotel : list) {
            System.out.println(hotel);
        }
        session.close();
    }
}

3、Map類型

a、返回單條記錄的map,key為屬性,值為屬性值。resultType為map

hotelMapper接口

package com.pjf.mybatis.dao;
import java.util.Map;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    // 返回值為Map,key為屬性名,value為屬性值
    public Map<String, Object> getHotel(Integer i);
}

hotelMapper.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.pjf.mybatis.dao.HotelMapper">
    <!-- 返回值為map,resultType為map -->
    <select id="getHotel" resultType="map">
        select * from hotel
        where
        id=#{id}
    </select>
</mapper>

測(cè)試類:返回id=1001的酒店

package com.pjf.mybatis;
import java.io.IOException;
import java.io.InputStream;
import java.util.Map;
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 org.junit.Test;
import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel;
public class TestHotel {
    public SqlSessionFactory sqlSessionFactory() throws IOException {
        // mybatis的配置文件
        String resource = "mybatis_config.xml";
        // 使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
        return sessionFactory;
    }
    // 查
    @Test
    public void getHotel() throws IOException {
        SqlSessionFactory sessionFactory = sqlSessionFactory();
        SqlSession session = sessionFactory.openSession();
        HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
        System.out.println(hotelMapper.getClass());
        // 返回值為map
        Map<String, Object> map = hotelMapper.getHotel(1001);
        System.out.println(map);
        session.close();
    }
}

b、返回多條記錄的map,key為任意一屬性,值為對(duì)象類型。如Map<String,Hotel>,resultType為Hotel

返回多條記錄的map時(shí),key為任意一屬性,值為對(duì)象類型,不過key需要通過@MapKey("hotelName")指定對(duì)象中一個(gè)屬性名為key

實(shí)例:

hotelMapper接口

package com.pjf.mybatis.dao;
import java.util.Map;
import org.apache.ibatis.annotations.MapKey;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    // 返回值為Map,key需要通過@MapKey("屬性名")來指定javaBean中的一個(gè)屬性名為key,value為對(duì)象
    @MapKey("hotelName")
    public Map<String, Hotel> getHotel(Integer i);
}

hotelMapper.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.pjf.mybatis.dao.HotelMapper">
    <!-- 返回值為map,resultType為對(duì)象的全類名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

測(cè)試類:返回價(jià)格>1000以上的酒店

package com.pjf.mybatis;
import java.io.IOException;
import java.io.InputStream;
import java.util.Map;
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 org.junit.Test;
import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel;
public class TestHotel {
    public SqlSessionFactory sqlSessionFactory() throws IOException {
        // mybatis的配置文件
        String resource = "mybatis_config.xml";
        // 使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
        return sessionFactory;
    }
    // 查
    @Test
    public void getHotel() throws IOException {
        SqlSessionFactory sessionFactory = sqlSessionFactory();
        SqlSession session = sessionFactory.openSession();
        HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
        System.out.println(hotelMapper.getClass());
        // 返回值為map
        Map<String, Hotel> map = hotelMapper.getHotel(1000);
        System.out.println(map);
        session.close();
    }
}

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Redis在springboot中的使用教程

    Redis在springboot中的使用教程

    這篇文章主要介紹了Redis在springboot中的使用教程,本文實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2018-06-06
  • Java中Spring對(duì)事務(wù)的支持詳解

    Java中Spring對(duì)事務(wù)的支持詳解

    這篇文章主要介紹了Java中Spring對(duì)事務(wù)的支持詳解,Spring對(duì)事務(wù)的支持有兩種方式,一是自己編寫事務(wù),精確控制事務(wù)的邊界,二是采用聲明事務(wù)的方式,使用AOP來完成,需要的朋友可以參考下
    2023-07-07
  • spring boot過濾器FilterRegistrationBean實(shí)現(xiàn)方式

    spring boot過濾器FilterRegistrationBean實(shí)現(xiàn)方式

    這篇文章主要介紹了spring boot過濾器FilterRegistrationBean實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • JavaScript的基本類型值-String類型

    JavaScript的基本類型值-String類型

    String類型用于表示由零或多個(gè)16位Unicode字符組成的字符序列,即字符串。在JavaScript中沒有單個(gè)的字符型,都是字符串。這篇文章主要介紹了JavaScript的基本類型值String類型,需要的朋友可以參考下
    2017-02-02
  • java判斷某個(gè)點(diǎn)是否在所畫多邊形/圓形內(nèi)

    java判斷某個(gè)點(diǎn)是否在所畫多邊形/圓形內(nèi)

    這篇文章主要為大家詳細(xì)介紹了java判斷某個(gè)點(diǎn)是否在所畫多邊形或圓形內(nèi)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Java 獲取本機(jī)的IP與MAC地址實(shí)現(xiàn)詳解

    Java 獲取本機(jī)的IP與MAC地址實(shí)現(xiàn)詳解

    這篇文章主要介紹了Java 獲取本機(jī)的IP與MAC地址實(shí)現(xiàn)詳解的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • macOS下Spring Boot開發(fā)環(huán)境搭建教程

    macOS下Spring Boot開發(fā)環(huán)境搭建教程

    這篇文章主要為大家詳細(xì)介紹了macOS下Spring Boot開發(fā)環(huán)境搭建教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • java編程題之從上往下打印出二叉樹

    java編程題之從上往下打印出二叉樹

    這篇文章主要為大家詳細(xì)介紹了java編程題之從上往下打印出二叉樹,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • sentinel流量控制框架(目錄設(shè)置)

    sentinel流量控制框架(目錄設(shè)置)

    Sentinel?是面向分布式服務(wù)架構(gòu)的高可用流量防護(hù)組件幫助開發(fā)者保障微服務(wù)的穩(wěn)定性,本文重點(diǎn)給大家介紹sentinel流量控制框架的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2022-03-03
  • Java中獲取時(shí)間戳的三種方式對(duì)比實(shí)現(xiàn)

    Java中獲取時(shí)間戳的三種方式對(duì)比實(shí)現(xiàn)

    這篇文章主要介紹了Java中獲取時(shí)間戳的三種方式對(duì)比實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01

最新評(píng)論