mybatis Mapper的xml文件中resultType值的使用說明
Mapper的xml文件中resultType值
①返回一般數(shù)據(jù)類型的值
比如根據(jù)id或者字段條件查詢獲取表中的某一個字段值
User Sel(int id); //根據(jù)id查詢
SQL映射文件
<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 |
②當(dāng)返回類型是javaBean
<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"/>
③當(dāng)返回是List類型
有時候我們需要模糊查詢或者是全表查詢,返回的數(shù)據(jù)是多條的, 那么可以把多條數(shù)據(jù)保存到list里面的。
mapper 接口
List<User> getUsers();
SQL映射文件:
<select id="getUsers" resultType="com.tx.entity.User"> select * from user </select>
這里需要注意的是返回是List類型 但是resultType依然是javaBean, 有些人會困惑這里怎么不是集合類型呢?其實透過現(xiàn)象看本質(zhì), 還是JavaBean。
④返回類型數(shù)Map結(jié)構(gòu)
當(dāng)我們在查詢的時候返回一條數(shù)據(jù)的時候,我們可以把{字段名,字段值}封裝成Map結(jié)構(gòu)。
Map<String, Object> findUserByName(Integer id);
SQL 映射文件:
<select id="findUserByName" resultType="string">
select userName from user where id=#{id};
</select>
⑤說一下關(guān)于mybatis里面mapper層中傳入多個參數(shù)的方法
1.其實可以看成是多個參數(shù)的
public List<User> findUser( String name1, String name2);
對應(yīng)的SQL映射文件:
<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框架)里面會報錯,我看網(wǎng)上說是可以的 我嘗試很多好像不行,下面貼出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<User> findUser( @Param("name1") String name1, @Param("name2") String name2);
對應(yīng)的SQL文件:
<select id="findUser" resultType="com.tx.springboottestdemo.entity.User">
select * from user_test where userName = #{name1} and realName = #{name2}
</select>
3.可以把參數(shù)封裝到Map里面
有些時候我們的業(yè)務(wù)數(shù)據(jù)查詢沒有定義對應(yīng)的POJO,就進行參數(shù)的封裝操作。
public List<User> findUser1(Map<String, Object> map);
對應(yīng)的SQL文件:
<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映射文件中定義返回值類型,返回值有基本類型,對象類型,List類型,Map類型等?,F(xiàn)總結(jié)一下再解釋
總結(jié)
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
<?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>
測試類:
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的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
InputStream is = Resources.getResourceAsStream(resource);
// 構(gòu)建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接口
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
<?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>
測試類:
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的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
InputStream is = Resources.getResourceAsStream(resource);
// 構(gòu)建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接口
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
<?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的酒店
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的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
InputStream is = Resources.getResourceAsStream(resource);
// 構(gòu)建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接口
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文件
<?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以上的酒店
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的配置文件(它也加載關(guān)聯(lián)的映射文件)TestHotel.class.getClassLoader()
InputStream is = Resources.getResourceAsStream(resource);
// 構(gòu)建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();
}
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring boot過濾器FilterRegistrationBean實現(xiàn)方式
這篇文章主要介紹了spring boot過濾器FilterRegistrationBean實現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10
macOS下Spring Boot開發(fā)環(huán)境搭建教程
這篇文章主要為大家詳細(xì)介紹了macOS下Spring Boot開發(fā)環(huán)境搭建教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01

