您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。