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

目录

  • Mapper的xml文件中resultType值
    • ①返回一般数据类型的值
    • ②当返回类型是javaBean
    • ③当返回是List类型
    • ④返回类型数Map结构
    • ⑤说一下关于mybatis里面mapper层中传入多个参数的方法
  • mybatis学习之resultType解析
    • 总结
    • 1、对象类型
    • 2、List类型
    • 3、Map类型

Mapper的xml文件中resultType值
①返回一般数据类型的值
比如根据id或者字段条件查询获取表中的某一个字段值
User Sel(int id); //根据id查询

SQL映射文件
//注意这个写了类全名 select username from user_test where id = #{id}

如果需要简写的话 需要定义resultType的别名
java 的基本类型不需要别名的:
别名 映射的类型
_byte byte
_long long
_short short
_int int
_boolean boolean
integer Integer
string String
date Date
boolean Boolean

②当返回类型是javaBean
select * from user_test where id = #{id}


③当返回是List类型
有时候我们需要模糊查询或者是全表查询,返回的数据是多条的, 那么可以把多条数据保存到list里面的。
mapper 接口
List getUsers();

SQL映射文件:
select * from user

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

④返回类型数Map结构
当我们在查询的时候返回一条数据的时候,我们可以把{字段名,字段值}封装成Map结构。
Map findUserByName(Integer id);

SQL 映射文件:
select userName from user where id=#{id};


⑤说一下关于mybatis里面mapper层中传入多个参数的方法
1.其实可以看成是多个参数的
public List findUser( String name1,String name2);

对应的SQL映射文件:
select * from user_test where userName = #{0} and realName = #{1}

其中里面#{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 findUser( @Param("name1") String name1, @Param("name2") String name2);

对应的SQL文件:
select * from user_test where userName = #{name1} and realName = #{name2}

3.可以把参数封装到Map里面
有些时候我们的业务数据查询没有定义对应的POJO,就进行参数的封装操作。
public List findUser1(Map map);

对应的SQL文件:
select * from user_test where userName = #{username} and realName = #{realname}


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 {//返回值类型为Hotelpublic Hotel getHotel(Integer i); }

HotelMapper.xml
select * from hotelwhereid=#{id}

测试类:
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; }// 查@Testpublic 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,resultType为Hotel
实例:
hotelMapper接口
package com.pjf.mybatis.dao; import java.util.List; import com.pjf.mybatis.po.Hotel; public interface HotelMapper {// 返回值为Listpublic List getHotel(Integer i); }

【mybatis|mybatis Mapper的xml文件中resultType值的使用说明】hotelMapper.xml
select * from hotelwhereprice>#{price}

测试类:
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; }// 查@Testpublic void getHotel() throws IOException {SqlSessionFactory sessionFactory = sqlSessionFactory(); SqlSession session = sessionFactory.openSession(); HotelMapper hotelMapper = session.getMapper(HotelMapper.class); System.out.println(hotelMapper.getClass()); // 返回值为ListList 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 getHotel(Integer i); }

hotelMapper.xml
select * from hotelwhereid=#{id}

测试类:返回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; }// 查@Testpublic void getHotel() throws IOException {SqlSessionFactory sessionFactory = sqlSessionFactory(); SqlSession session = sessionFactory.openSession(); HotelMapper hotelMapper = session.getMapper(HotelMapper.class); System.out.println(hotelMapper.getClass()); // 返回值为mapMap map = hotelMapper.getHotel(1001); System.out.println(map); session.close(); }}

b、返回多条记录的map,key为任意一属性,值为对象类型。如Map,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 getHotel(Integer i); }

hotelMapper.xml文件
select * from hotelwhereprice>#{price}

测试类:返回价格>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; }// 查@Testpublic void getHotel() throws IOException {SqlSessionFactory sessionFactory = sqlSessionFactory(); SqlSession session = sessionFactory.openSession(); HotelMapper hotelMapper = session.getMapper(HotelMapper.class); System.out.println(hotelMapper.getClass()); // 返回值为mapMap map = hotelMapper.getHotel(1000); System.out.println(map); session.close(); }}

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

    推荐阅读