本篇文章給大家分享的是有關mybatis中怎么實現輸入映射和輸出映射,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
輸入映射
Mybatis支持輸入
哪些類型
簡單類型、POJO,HashMap,POJO的包裝的類型。
需求:查詢用戶列表:已經下過訂單男性用戶,那么傳入的參數包含用戶信息(User)和訂單信息(Order)
輸出映射
resultType
(1)支持的類型
基本類型、pojo、hashMap
(2)輸出是POJO和POJO列表問題
不管是輸出是單個POJO,還是POJO列表,在Mapper.xml中resultType都是一樣的,只是在Mapper接口中返回值類型不一樣。
(3)使用條件
使用resultType進行輸出映射的時候,只要查詢出來的列名和POJO的屬性名一致,該列才可以映射成功。
只要查詢出來的列名和屬性名有一個能對應的上,就會創建POJO對象。
如果查詢出來的列名和屬性名沒有一個能對應上,就不會創建POJO對象。

sqlMapconfig.xml核心配置文件
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <environments default="devlelopment"> <environment id="devlelopment"> <transactionManager type="JDBC"></transactionManager> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/mysql04"></property> <property name="username" value="root"></property> <property name="password" value="123"></property> </dataSource> </environment> </environments> <!--(6)在核心配置文件加載映射文件--> <mappers> <mapper resource="com/sgl/demo2/User.xml"></mapper> <mapper resource="com/sgl/demo3/mapper/UserMapper.xml"></mapper> <mapper resource="com/sgl/demo5/mapper/UserMapper.xml"></mapper> </mappers> </configuration>
UserMapper .java
package com.sgl.demo5.mapper;
import com.sgl.demo5.pojo.User;
import com.sgl.demo5.vo.UserQueryVo;
import java.util.List;
public interface UserMapper {
// 根據返回類型選擇selectOne或者selectList
public List<User> findUserList(UserQueryVo userQueryVo);
}UserMapper .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">
<!--namespace :命名空間,對Sql進行分類管理,SQL分離-->
<mapper namespace="com.sgl.demo5.mapper.UserMapper">
<!--
id:表示配置文件中的SQL,稱為statement 的Id
parameterType:參數的類型
resultType:返回值的類型,
如果返回值是一個集合,那么類型就寫集合中元素的類型
-->
<!--查詢用戶列表,主鍵查詢-->
<select id="findUserList" parameterType="com.sgl.demo5.vo.UserQueryVo"
resultType="com.sgl.demo5.pojo.User">
select username,id from user where username like "%"#{user.username}"%" and sex=#{user.sex}
</select>
</mapper>UserQueryVo .java
package com.sgl.demo5.vo;
import com.sgl.demo5.pojo.User;
public class UserQueryVo {
private User user;
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
}Test1.java
package com.sgl.demo5.test;
import com.sgl.demo5.mapper.UserMapper;
import com.sgl.demo5.pojo.User;
import com.sgl.demo5.vo.UserQueryVo;
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.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class Test1 {
private SqlSessionFactory sqlSessionFactory;
@Before
public void fun0() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapconfig.xml");
this.sqlSessionFactory= new SqlSessionFactoryBuilder().build(resourceAsStream);
}
@Test
public void fun1()
{
SqlSession sqlSession = this.sqlSessionFactory.openSession();
UserMapper userMapper = sqlSession.getMapper( UserMapper.class );
UserQueryVo userQueryVo=new UserQueryVo();
User user=new User();
user.setUsername("小");
user.setSex("1");
userQueryVo.setUser(user);
List<User> userList = userMapper.findUserList(userQueryVo);
for ( User u:userList
) {
System.out.println(u);
}
}
}以上就是mybatis中怎么實現輸入映射和輸出映射,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。