欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

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

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

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比康保網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式康保網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋康保地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。

輸入映射

Mybatis支持輸入

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

輸出映射

resultType

(1)支持的類型

基本類型、pojo、hashMap

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

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

(3)使用條件

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

mybatis中怎么實(shí)現(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 :命名空間,對(duì)Sql進(jìn)行分類管理,SQL分離-->
<mapper namespace="com.sgl.demo5.mapper.UserMapper">

  <!--
  id:表示配置文件中的SQL,稱為statement 的Id
  parameterType:參數(shù)的類型
  resultType:返回值的類型,
      如果返回值是一個(gè)集合,那么類型就寫集合中元素的類型
  -->
  <!--查詢用戶列表,主鍵查詢-->
  <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中怎么實(shí)現(xiàn)輸入映射和輸出映射,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享文章:mybatis中怎么實(shí)現(xiàn)輸入映射和輸出映射
鏈接URL:http://chinadenli.net/article22/ppghjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、網(wǎng)頁設(shè)計(jì)公司、外貿(mào)網(wǎng)站建設(shè)軟件開發(fā)、、網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)