溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis中怎么實現(xiàn)輸入映射和輸出映射

發(fā)布時間:2021-06-09 18:10:27 來源:億速云 閱讀:165 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關mybatis中怎么實現(xiàn)輸入映射和輸出映射,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

輸入映射

Mybatis支持輸入

哪些類型
簡單類型、POJO,HashMap,POJO的包裝的類型。
需求:查詢用戶列表:已經下過訂單男性用戶,那么傳入的參數(shù)包含用戶信息(User)和訂單信息(Order)

輸出映射

resultType

(1)支持的類型

基本類型、pojo、hashMap

(2)輸出是POJO和POJO列表問題

不管是輸出是單個POJO,還是POJO列表,在Mapper.xml中resultType都是一樣的,只是在Mapper接口中返回值類型不一樣。

(3)使用條件

使用resultType進行輸出映射的時候,只要查詢出來的列名和POJO的屬性名一致,該列才可以映射成功。
只要查詢出來的列名和屬性名有一個能對應的上,就會創(chuàng)建POJO對象。
如果查詢出來的列名和屬性名沒有一個能對應上,就不會創(chuàng)建POJO對象。

mybatis中怎么實現(xiàn)輸入映射和輸出映射

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 {
//  根據(jù)返回類型選擇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:參數(shù)的類型
  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中怎么實現(xiàn)輸入映射和輸出映射,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI