千家信息网

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

发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,如何使用mybatis Mapper的xml文件中resultType值,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。M
千家信息网最后更新 2024年11月19日如何使用mybatis Mapper的xml文件中resultType值

如何使用mybatis Mapper的xml文件中resultType值,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

Mapper的xml文件中resultType值

①返回一般数据类型的值

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

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

SQL映射文件

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

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

别名映射的类型
_bytebyte
_longlong
_shortshort
_intint
_booleanboolean
integerInteger
stringString
dateDate
booleanBoolean

②当返回类型是javaBean

    

③当返回是List类型

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

mapper 接口

List getUsers();

SQL映射文件:

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

④返回类型数Map结构

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

Map findUserByName(Integer id);

SQL 映射文件:

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

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

public List findUser( String name1,  String name2);

对应的SQL映射文件:

其中里面#{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文件:

3.可以把参数封装到Map里面

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

public List findUser1(Map map);

对应的SQL文件:

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

        

测试类:

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,resultType为Hotel

实例:

hotelMapper接口

package com.pjf.mybatis.dao;import java.util.List;import com.pjf.mybatis.po.Hotel;public interface HotelMapper {    // 返回值为List    public List getHotel(Integer i);}

hotelMapper.xml

        

测试类:

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

        

测试类:返回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 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文件

        

测试类:返回价格>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 map = hotelMapper.getHotel(1000);        System.out.println(map);        session.close();    }}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

0