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