一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - mybatis Mapper的xml文件中resultType值的使用說(shuō)明

mybatis Mapper的xml文件中resultType值的使用說(shuō)明

2022-02-13 14:31Bonyin Java教程

這篇文章主要介紹了mybatis Mapper的xml文件中resultType值的使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mapper的xml文件中resultType值

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

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

?
1
User Sel(int id); //根據(jù)id查詢(xún)

SQL映射文件

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

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

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

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

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

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

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

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

mapper 接口

?
1
List<User> getUsers();

SQL映射文件:

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

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

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

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

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

SQL 映射文件:

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

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

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

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

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

?
1
2
3
<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)上說(shuō)是可以的 我嘗試很多好像不行,下面貼出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.可以看做是加了注解

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

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

?
1
2
3
<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ù)查詢(xún)沒(méi)有定義對(duì)應(yīng)的POJO,就進(jìn)行參數(shù)的封裝操作。

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

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

?
1
2
3
<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映射文件中定義返回值類(lèi)型,返回值有基本類(lèi)型,對(duì)象類(lèi)型,List類(lèi)型,Map類(lèi)型等。現(xiàn)總結(jié)一下再解釋

總結(jié)

resultType:

1、基本類(lèi)型:resultType=基本類(lèi)型

2、List類(lèi)型:resultType=List中元素的類(lèi)型

3、Map類(lèi)型:

單條記錄:resultType =map

多條記錄:resultType =Map中value的類(lèi)型

1、對(duì)象類(lèi)型

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

實(shí)例:

hotelMapper接口

?
1
2
3
4
5
6
package com.pjf.mybatis.dao;
import com.pjf.mybatis.po.Hotel;
public interface HotelMapper {
    //返回值類(lèi)型為Hotel
    public Hotel getHotel(Integer i);
}

HotelMapper.xml

?
1
2
3
4
5
6
7
8
9
10
<?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直接寫(xiě)對(duì)象的全類(lèi)名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        id=#{id}
    </select>
</mapper>

測(cè)試類(lèi):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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";
        // 使用類(lèi)加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠(chǎng)
        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ì)象,打印出來(lái)       
        Hotel hotel = hotelMapper.getHotel(1001);
        System.out.println(hotel);
        session.close();
    }
}

2、List類(lèi)型

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

實(shí)例:

hotelMapper接口

?
1
2
3
4
5
6
7
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

?
1
2
3
4
5
6
7
8
9
10
<?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中元素的全類(lèi)名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

測(cè)試類(lèi):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
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";
        // 使用類(lèi)加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠(chǎng)
        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類(lèi)型

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

hotelMapper接口

?
1
2
3
4
5
6
7
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

?
1
2
3
4
5
6
7
8
9
10
<?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è)試類(lèi):返回id=1001的酒店

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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";
        // 使用類(lèi)加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠(chǎng)
        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ì)象類(lèi)型。如Map<String,Hotel>,resultType為Hotel

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

實(shí)例:

hotelMapper接口

?
1
2
3
4
5
6
7
8
9
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需要通過(guò)@MapKey("屬性名")來(lái)指定javaBean中的一個(gè)屬性名為key,value為對(duì)象
    @MapKey("hotelName")
    public Map<String, Hotel> getHotel(Integer i);
}

hotelMapper.xml文件

?
1
2
3
4
5
6
7
8
9
10
<?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ì)象的全類(lèi)名 -->
    <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
        select * from hotel
        where
        price>#{price}
    </select>
</mapper>

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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";
        // 使用類(lèi)加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
        InputStream is = Resources.getResourceAsStream(resource);
        // 構(gòu)建sqlSession的工廠(chǎng)
        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è)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/tryll/article/details/100087608

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美一区二区三区精品影视 | 99久久精品免费看国产一区 | 好大好硬好深好爽想要之黄蓉 | 国产精品久久久久久久久免费观看 | 成年人视频在线播放 | 日韩首页 | www久久精品 | 色婷婷在线视频 | 91精品国产品国语在线不卡 | 4hu永久地域网名入口 | 婷婷色伊人 | 好大好硬抽搐好爽想要 | 成人先锋| 亚洲精品黄色 | 999热这里只有精品 999久久久免费精品国产牛牛 | 亚洲精品专区 | 欧美精品日韩 | 9总探花新品牛仔背带裤 | 暖暖中国免费观看高清完整版 | 免费看黄色片网站 | 天天色国产 | 日本人交换乱理伦片 | 亚洲区视频在线观看 | 黄网久久 | 全肉一女n男np高h乳 | 国产日韩精品一区二区在线观看播放 | 国产亚洲欧美成人久久片 | 明星ai智能人脸替换造梦在线播放 | 女同69式互添在线观看免费 | 天天久久综合 | 国产尤物精品视频 | 青青青国产视频 | 国产精品对白刺激久久久 | 精品欧美一区二区精品久久 | 91porny新九色在线 | 蘑菇香蕉茄子绿巨人丝瓜草莓 | 狠狠久久久久综合网 | 国产日韩在线 | 91欧美国产 | 2019中文字幕 | 精品成人一区二区三区免费视频 |