中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

如何使用mybatis Mapper的xml文件中resultType值

發布時間:2021-10-09 18:09:02 來源:億速云 閱讀:185 作者:柒染 欄目:開發技術

如何使用mybatis Mapper的xml文件中resultType值,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

Mapper的xml文件中resultType值

①返回一般數據類型的值

比如根據id或者字段條件查詢獲取表中的某一個字段值

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

SQL映射文件

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

如果需要簡寫的話 需要定義resultType的別名

java 的基本類型不需要別名的:

別名映射的類型
_bytebyte
_longlong
_shortshort
_intint
_booleanboolean
integerInteger
stringString
dateDate
booleanBoolean

②當返回類型是javaBean

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

③當返回是List類型

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

mapper 接口

List<User> getUsers();

SQL映射文件:

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

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

④返回類型數Map結構

當我們在查詢的時候返回一條數據的時候,我們可以把{字段名,字段值}封裝成Map結構。

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

SQL 映射文件:

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

⑤說一下關于mybatis里面mapper層中傳入多個參數的方法

1.其實可以看成是多個參數的

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

對應的SQL映射文件:

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

其中里面#{0}, #{1}默認是按照mybatis傳值的順序位置索引的 但是在springboot2.1(集成mybatis框架)里面會報錯,我看網上說是可以的 我嘗試很多好像不行,下面貼出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);

對應的SQL文件:

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

3.可以把參數封裝到Map里面

有些時候我們的業務數據查詢沒有定義對應的POJO,就進行參數的封裝操作。

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

對應的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學習之resultType解析

resultType是sql映射文件中定義返回值類型,返回值有基本類型,對象類型,List類型,Map類型等。現總結一下再解釋

總結

resultType:

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

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

3、Map類型:

單條記錄:resultType =map

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

1、對象類型

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

實例:

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

測試類:

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的配置文件(它也加載關聯的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構建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對象,打印出來        
        Hotel hotel = hotelMapper.getHotel(1001);
        System.out.println(hotel);
        session.close();
    }
}

2、List類型

返回值為List類型,resultType為List中對象的類型,如List<Hotel>,resultType為Hotel

實例:

hotelMapper接口

package com.pjf.mybatis.dao;
import java.util.List;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    // 返回值為List
    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">
    <!-- 返回值為List,resultType為List中元素的全類名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

測試類:

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的配置文件(它也加載關聯的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構建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());
        // 返回值為List
        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>

測試類:返回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的配置文件(它也加載關聯的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構建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為任意一屬性,值為對象類型。如Map<String,Hotel>,resultType為Hotel

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

實例:

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中的一個屬性名為key,value為對象
    @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為對象的全類名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

測試類:返回價格>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的配置文件(它也加載關聯的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構建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();
    }
}

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

双流县| 洪湖市| 瑞安市| 梓潼县| 榆社县| 喀喇沁旗| 若尔盖县| 富川| 金湖县| 台南市| 巴林左旗| 葫芦岛市| 临澧县| 白银市| 晋城| 绥滨县| 乐安县| 浦城县| 昭平县| 丰城市| 英德市| 石台县| 洛川县| 饶平县| 海淀区| 遵义县| 武鸣县| 开阳县| 忻州市| 洞头县| 梓潼县| 临洮县| 阳曲县| 山东省| 会昌县| 临武县| 霞浦县| 商河县| 太和县| 云和县| 治县。|