好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

Mapper的xml文件中resultType值

①返回一般数据类型的值

比如根据id或者字段条件查询获取表中的某一个字段值

?

1

User Sel( int id); //根据id查询

SQL映射文件

?

1

2

3

< select id= "Sel" resultType= "java.lang.String" > //注意这个写了类全名

     select username from user_test where id = #{id}

</ select >

如果需要简写的话 需要定义resultType的别名

java 的基本类型不需要别名的:

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

②当返回类型是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> 

<! -- 针对单个别名定义 type:类型的路径 alias:别名 --> 

<typeAlias type= "cn.itcast.mybatis.po.User" alias= "user" />

③当返回是List类型

有时候我们需要模糊查询或者是全表查询,返回的数据是多条的, 那么可以把多条数据保存到list里面的。

mapper 接口

?

1

List<User> getUsers();

SQL映射文件:

?

1

2

3

< select id= "getUsers" resultType= "com.tx.entity.User" >

select * from user

</ select >

这里需要注意的是返回是List类型 但是resultType依然是javaBean, 有些人会困惑这里怎么不是集合类型呢?其实透过现象看本质, 还是JavaBean。

④返回类型数Map结构

当我们在查询的时候返回一条数据的时候,我们可以把{字段名,字段值}封装成Map结构。

?

1

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

SQL 映射文件:

?

1

2

3

< select id= "findUserByName" resultType= "string" >

select userName from user where id=#{id};

</ select >

⑤说一下关于mybatis里面mapper层中传入多个参数的方法

1.其实可以看成是多个参数的

?

1

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

对应的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}默认是按照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.可以看做是加了注解

?

1

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

对应的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.可以把参数封装到Map里面

有些时候我们的业务数据查询没有定义对应的POJO,就进行参数的封装操作。

?

1

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

对应的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学习之resultType解析

resultType是sql映射文件中定义返回值类型,返回值有基本类型,对象类型,List类型,Map类型等。现总结一下再解释

总结

resultType:

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

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

3、Map类型:

单条记录:resultType =map

多条记录:resultType =Map中value的类型

1、对象类型

对于对象类型resultType直接写对象的全类名就可以了

实例:

hotelMapper接口

?

1

2

3

4

5

6

package com.pjf.mybatis.dao;

import com.pjf.mybatis.po.Hotel;

public interface HotelMapper {

     //返回值类型为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直接写对象的全类名 -->

     < select id = "getHotel" resultType = "com.pjf.mybatis.po.Hotel" >

         select * from hotel

         where

         id=#{id}

     </ select >

</ mapper >

测试类:

?

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" ;

         // 使用类加载器加载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接口

?

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 {

     // 返回值为List

     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" >

     <!-- 返回值为List,resultType为List中元素的全类名 -->

     < select id = "getHotel" resultType = "com.pjf.mybatis.po.Hotel" >

         select * from hotel

         where

         price>#{price}

     </ select >

</ mapper >

测试类:

?

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" ;

         // 使用类加载器加载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接口

?

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 >

测试类: 返回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" ;

         // 使用类加载器加载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接口

?

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需要通过@MapKey("属性名")来指定javaBean中的一个属性名为key,value为对象

     @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为对象的全类名 -->

     < select id = "getHotel" resultType = "com.pjf.mybatis.po.Hotel" >

         select * from hotel

         where

         price>#{price}

     </ select >

</ mapper >

测试类: 返回价格>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" ;

         // 使用类加载器加载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();

     }

}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

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

查看更多关于mybatis Mapper的xml文件中resultType值的使用说明的详细内容...

  阅读:18次