欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis查詢語句返回對象和泛型集合的操作

 更新時間:2021年07月30日 11:53:56   作者:Sesshoumaru華  
這篇文章主要介紹了Mybatis查詢語句返回對象和泛型集合的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Mybatis查詢語句返回對象和泛型集合

EmpMapper映射接口:

package cn.et.mybatis.lesson03; 
import java.util.List; 
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select; 
public interface EmpMapper { 
 
 /**
  * 查詢單條數據,
  *  每一列的列名都會去Emp實體類中去匹配對應的屬性
  *   匹配時會把二邊都轉為小字母進行匹配
  *   匹配成功就會調用Emp實體類中對象的set方法
  * 
  * 如果列名和Emp的屬性匹配不上,
  *  1.為查詢結果的列設置一個別名
  *      2.將列名ename和屬性ename1建立一個關系 單個屬性建立關系
  * 
  *   column是不區(qū)分大小寫的,property是區(qū)分大小寫的
  * @return
  */
 @Results(
   {
    @Result(column="ename",property="ename1"),
    @Result(column="empNo",property="empNo1"),
    @Result(column="sal",property="sal1"),
   }
 )
 @Select("select * from emp where empno=#{0}")
 public Emp queryEmpByEmpNo(String empNo); 
 
 /**
  * 查詢出多條數據,每一條數據都是一個Emp對象
  * 每一列的列名都會去Emp實體類中去匹配對應的屬性
  *   匹配時會把二邊都轉為小字母進行匹配
  *   匹配成功就會調用Emp實體類中對象的set方法
  * 如果沒有一條數據匹配成功,則不會創(chuàng)建Emp對象
  * @param empNo
  * @return
  */
 @Results(
   {
    @Result(column="ename",property="ename1"),
    @Result(column="empNo",property="empNo1"),
    @Result(column="sal",property="sal1"),
   }
 )
 @Select("select * from emp")
 public List<Emp> queryEmp(); 
}

測試類:

package cn.et.mybatis.lesson03; 
import java.io.InputStream;
import java.util.List; 
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
 
public class TestMybatis { 
 public static SqlSession getSession(){
  String resource = "/cn/et/mybatis/lesson03/mybatis.xml";
  InputStream inputStream = TestMybatis.class.getResourceAsStream(resource);
  SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  //打開會話
  SqlSession session = sqlSessionFactory.openSession();
  return session;
 }
 
 public static void main(String[] args) {
  SqlSession session = getSession();
  EmpMapper emp = session.getMapper(EmpMapper.class);
  Emp obj = emp.queryEmpByEmpNo("8000");
  System.out.println(obj);
 } 
 
 @Test
 public void test(){
  SqlSession session = getSession();
  EmpMapper emp = session.getMapper(EmpMapper.class);
  List<Emp> result = emp.queryEmp();
  for (Emp emp2 : result) {
   System.out.println(emp2);
  }
 }
}

xml映射-----------

dept_mapper.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必需跟接口的全名一致
 -->
<mapper namespace="cn.et.mybatis.lesson03.resultEntityXml.DeptMapper">
 
 <!-- column是不區(qū)分大小寫的,property是區(qū)分大小寫的 -->
  <resultMap type="cn.et.mybatis.lesson03.resultEntityXml.Dept" id="myDept">
    <result column="deptno" property="deptno1"/>
    <result column="dname" property="dname1"/>
    <result column="loc" property="loc1"/>
  </resultMap>
  <select id="queryDept" resultMap="myDept">
 select * from dept where deptno=#{0}
  </select>  
</mapper>

測試類:

package cn.et.mybatis.lesson03.resultEntityXml; 
import java.io.InputStream; 
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
 
public class TestMybatis { 
 public static SqlSession getSession(){
  String resource = "/cn/et/mybatis/lesson03/mybatis.xml";
  InputStream inputStream = TestMybatis.class.getResourceAsStream(resource);
  SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  //打開會話
  SqlSession session = sqlSessionFactory.openSession();
  return session;
 }
 
 public static void main(String[] args) {
  SqlSession session = getSession();
  DeptMapper dept = session.getMapper(DeptMapper.class);
  Dept result = dept.queryDept("10");
  System.out.println(result);  
 } 
}

mybatis查詢結果集有泛型屬性時可能出現的問題

問題:

當接收結果為map或者對象的屬性為泛型時:

@Data
public class GenericKeyValueVo<K,V> {
    private K key;
    private V value;
}

這時候如果直接將resultType指向對象全限定名稱時,可能會出現問題。因為如果查詢結果的某個字段大于1000會出現","如:1,000.56 。mybatis不會報錯,因為這個對象的這個屬性為泛型,可以接收。而當獲取結果之后即使定義接收的變量類型為:

在這里插入圖片描述

第二個屬性也會存入String類型的值。后續(xù)再處理可能就會出現將string轉為double數據類型轉換錯誤。

解決方法:

定義一個resultMap,指明javaType

    <resultMap id="StrKeyDoubleValueMap" type="com.meinergy.mkting.commons.entity.wholesale.vo.GenericKeyValueVo">
        <result column="key" property="key" javaType="java.lang.String"/>
        <result column="value" property="value" javaType="java.lang.Double"/>
    </resultMap>

再用一個convert函數規(guī)范查詢結果格式

convert(FORMAT(queryResult, decimal(12, 2))

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 解決Java & Idea啟動tomcat的中文亂碼問題

    解決Java & Idea啟動tomcat的中文亂碼問題

    這篇文章主要介紹了Java & Idea啟動tomcat的中文亂碼問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • springboot+websocket+redis搭建的實現

    springboot+websocket+redis搭建的實現

    這篇文章主要介紹了springboot+websocket+redis搭建的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • spring boot集成shiro詳細教程(小結)

    spring boot集成shiro詳細教程(小結)

    這篇文章主要介紹了spring boot 集成shiro詳細教程,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • MyBatis中執(zhí)行SQL語句的幾種方式總結

    MyBatis中執(zhí)行SQL語句的幾種方式總結

    MyBatis是一個優(yōu)秀的持久層框架,它支持定制化SQL、存儲過程以及高級映射,下面這篇文章主要給大家介紹了關于MyBatis中執(zhí)行SQL語句的幾種方式,需要的朋友可以參考下
    2024-04-04
  • java導出excel 瀏覽器直接下載或者或以文件形式導出

    java導出excel 瀏覽器直接下載或者或以文件形式導出

    這篇文章主要介紹了java導出excel 瀏覽器直接下載或者或以文件形式導出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Windows10安裝IDEA 2020.1.2的方法步驟

    Windows10安裝IDEA 2020.1.2的方法步驟

    這篇文章主要介紹了Windows10安裝IDEA 2020.1.2的方法步驟,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • SpringBoot+TestNG單元測試的實現

    SpringBoot+TestNG單元測試的實現

    本文主要介紹了SpringBoot+TestNG單元測試的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-07-07
  • springboot?集成identityserver4身份驗證的過程解析

    springboot?集成identityserver4身份驗證的過程解析

    這篇文章主要介紹了springboot?集成identityserver4身份驗證的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • 理解java多線程中ExecutorService使用

    理解java多線程中ExecutorService使用

    這篇文章主要幫助大家理解java多線程中ExcetorServiced的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • SpringBoot如何實現持久化登錄狀態(tài)獲取

    SpringBoot如何實現持久化登錄狀態(tài)獲取

    這篇文章主要介紹了SpringBoot 如何實現持久化登錄狀態(tài)獲取,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11

最新評論