本文主要讲述如何在mybatis中进行查询操作【详解】

一. 查询User对象

  1.查询单个对象User

  SelectUser接口声明如下

// 主要条件是使用id
public interface SelectUser { // 查询单行数据,返回对象User
User getUserSingleByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">

<!--User getUserSingleByID(@Param("id") int id)-->
<select id="getUserSingleByID" resultType="User">
select * from t_user where id = #{id};
</select>
</mapper>

  2. 查询多个对象User

  SelectUser接口声明如下

// 主要条件是使用id
public interface SelectUser { // 查询多行数据,返回User类的集合【查询 >= id 的数据】
List<User> getUserListByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">

    <!--List<User> getUserListByID(@Param("id") int id)-->
<select id="getUserListByID" resultType="User">
select * from t_user where id >= #{id}
</select>
</mapper>

  问题:当查询单个对象时,是否可以用List<User>作为返回类型?

  SelectUser接口声明如下

// 主要条件是使用id
public interface SelectUser { // 查询单行数据,返回对象User
List<User> getUserSingleByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">
<!--User getUserSingleByID(@Param("id") int id)-->
<select id="getUserSingleByID" resultType="User">
select * from t_user where id = #{id};
</select>
</mapper>

  测试test

    @Test
// 使用id查询单个数据User
public void selectUserByID(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SelectUser mapper = sqlSession.getMapper(SelectUser.class);
List<User> user = mapper.getUserSingleByID(12);
System.out.println(user);
sqlSession.close();
}

  测试结果如下

  运行结果正常

  总结:当返回的数据对象不清楚有几个的情况,建议使用List<User>

二. 查询字段

  1.查询单个字段【单行】

  SelectUser接口声明如下

// 主要条件是使用id
public interface SelectUser {
// 查询单个字段【单行】
// 返回类型根据字段的类型而定,具体问题具体分析
String getNameByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">

    <!--String getNameByID(@Param("id") int id)-->
<select id="getNameByID" resultType="string">
select username from t_user where id = #{id}
</select>
</mapper>

  注意:在SelectUser接口定义的方法 getNameByID() 的返回类型需要根据字段的类型来指明,或者直接使用Object。

  2. 查询单个字段【多行】

  SelectUser接口声明如下

public interface SelectUser {
// 查询单个字段【多行】
List<String> getNameRowsByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">

    <!--List<String> getNameRowsByID(@Param("id") int id);-->
<select id="getNameRowsByID" resultType="string">
select username from t_user where id >= #{id}
</select>
</mapper>

  与 一中查询多行数据类似,返回类型是List<字段类型或者Object>

  3. 查询多个字段【单行】

  SelectUser接口声明如下

// 主要条件是使用id
public interface SelectUser { // 查询多个字段【单行】
// Map<String,Object> 中 key是字段名,value是属性值
Map<String,Object> getColsByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">

    <!--Map<String,Object> getColsByID(@Param("id") int id)-->
<select id = "getColsByID" resultType="map">
select username,password,age from t_user where id = #{id}
</select>
</mapper>

  在SelectUser接口定义的方法返回类型是Map<String,Object>类型,

  Map<String,Object>的key是字段名,value是属性值,这里的Object用的巧妙

  4. 查询多个字段【多行】

  SelectUser接口声明如下

public interface SelectUser {
// 查询多个字段【多行】
// 此时不能使用 Map<String,Object> 作为返回类型,数据不止一条
// 方式1:使用List<Map<>>
List<Map<String,Object>> getClosRowsByID(@Param("id") int id);
// 方式2:使用@MapKey("字段名") 查出的结果 Map<Map<>>
// @MapKey("字段名"),key是字段名【唯一标志该行数据】value是该行数据
// 此时在xml文件,查询字段必须要包含唯一标识id
@MapKey("id")
// Map<String,Object> getMapsByID(@Param("id") int id);
Map<Integer,Object> getMapsByID(@Param("id") int id);
}

  SelectUser.xml文件声明如下

<mapper namespace="com.hspedu.mapper.SelectUser">
  <!--方式1:使用List<Map<>> -->
<!--Map<String,Object> getClosRowsByID(@Param("id") int id);-->
<select id="getClosRowsByID" resultType="map">
select username,password,age from t_user where id >= #{id}
</select>   <!--方式2:使用@MapKey注解 -->
<!--@MapKey("id")
Map<String,Object> getMapsByID(@Param("id") int id);-->
<select id="getMapsByID" resultType="map">
select id,username,password,age from t_user where id >= #{id}
</select> </mapper>

  方式1:测试test

    @Test
// 根据id查询多个字段【多行】方式一:
public void selectColsRowsByID(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SelectUser mapper = sqlSession.getMapper(SelectUser.class);
List<Map<String, Object>> mapList = mapper.getClosRowsByID(6);
// 遍历集合
for (Map<String, Object> map : mapList) {
System.out.println(map);
}
sqlSession.close();
}

  测试结果如下

{password=tom123, age=20, username=Tom}
{password=tom123, age=20, username=Tom}
{password=tom123, age=20, username=Tom}
{password=tom12345, age=20, username=jack}
{password=hsp12345, age=25, username=hsp}
{password=tom123, age=20, username=Tom}
{password=tom123, age=20, username=Tom}
{password=tom123, age=20, username=Tom}
{password=hsp12345, age=25, username=hsp}

  方式2:测试test

    @Test
// 根据id查询多个字段【多行】方式二:
public void selectMapsByID(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SelectUser mapper = sqlSession.getMapper(SelectUser.class);
Map<Integer, Object> maps = mapper.getMapsByID(6);
// 遍历map,注意此时map的结构 Map<id=Map,id=Map...>
Set<Integer> keySet = maps.keySet();
// java.lang.Integer cannot be cast to java.lang.String
// [16, 6, 9, 10, 11, 12, 13, 14, 15]
// id的字段类型: class java.lang.Integer.
// 因此需要将Map<String,Object> 变成Map<Integer,Object>
for (Integer s : keySet) {
System.out.println(maps.get(s));
}
sqlSession.close();
}

  测试结果如下

{password=hsp12345, id=16, age=25, username=hsp}
{password=tom123, id=6, age=20, username=Tom}
{password=tom123, id=9, age=20, username=Tom}
{password=tom123, id=10, age=20, username=Tom}
{password=tom12345, id=11, age=20, username=jack}
{password=hsp12345, id=12, age=25, username=hsp}
{password=tom123, id=13, age=20, username=Tom}
{password=tom123, id=14, age=20, username=Tom}
{password=tom123, id=15, age=20, username=Tom}

  注意方式1和方式2的区别

  方式1的返回类型是List<Map>,即 将查询到的每行结果 --存放-->Map<String,Object> ---封装--> List<Map<String,Object>>。

    List<Map<>>的结构如下

[{password=tom123, age=20, username=Tom},{password=tom123, age=20, username=Tom},
{password=tom123, age=20, username=Tom},
{password=tom12345, age=20, username=jack},
{password=hsp12345, age=25, username=hsp},
{password=tom123, age=20, username=Tom},
{password=tom123, age=20, username=Tom},
{password=tom123, age=20, username=Tom},
{password=hsp12345, age=25, username=hsp}]

  方式2是通过注解@MapKey("字段名"),注意这里的字段名是作为每行数据value的key【因此应该选择能够唯一标识某一行数据的字段名作为每行数据的key】。

    Map< " 字段名的值 " = Map<>>的结构如下

{16={password=hsp12345, id=16, age=25, username=hsp},
6={password=tom123, id=6, age=20, username=Tom},
9={password=tom123, id=9, age=20, username=Tom},
10={password=tom123, id=10, age=20, username=Tom},
11={password=tom12345, id=11, age=20, username=jack},
12={password=hsp12345, id=12, age=25, username=hsp},
13={password=tom123, id=13, age=20, username=Tom},
14={password=tom123, id=14, age=20, username=Tom},
15={password=tom123, id=15, age=20, username=Tom}}

MyBatis使用四(查询详解)的更多相关文章

  1. 深入浅出Mybatis系列四-配置详解之typeAliases别名(mybatis源码篇)

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 上篇文章<深入浅出Mybatis系列(三)---配置详解之properties ...

  2. Mybatis系列全解(四):全网最全!Mybatis配置文件XML全貌详解

    封面:洛小汐 作者:潘潘 做大事和做小事的难度是一样的.两者都会消耗你的时间和精力,所以如果决心做事,就要做大事,要确保你的梦想值得追求,未来的收获可以配得上你的努力. 前言 上一篇文章 <My ...

  3. ElasticSearch第四步-查询详解

    ElasticSearch系列学习 ElasticSearch第一步-环境配置 ElasticSearch第二步-CRUD之Sense ElasticSearch第三步-中文分词 ElasticSea ...

  4. Mybatis SQL映射文件详解

    Mybatis SQL映射文件详解 mybatis除了有全局配置文件,还有映射文件,在映射文件中可以编写以下的顶级元素标签: cache – 该命名空间的缓存配置. cache-ref – 引用其它命 ...

  5. Lucene系列六:Lucene搜索详解(Lucene搜索流程详解、搜索核心API详解、基本查询详解、QueryParser详解)

    一.搜索流程详解 1. 先看一下Lucene的架构图 由图可知搜索的过程如下: 用户输入搜索的关键字.对关键字进行分词.根据分词结果去索引库里面找到对应的文章id.根据文章id找到对应的文章 2. L ...

  6. MyBatis中@MapKey使用详解

    MyBatis中@MapKey使用详解我们在上一篇文章中讲到在Select返回类型中是返回Map时,是对方法中是否存在注解@MapKey,这个注解我也是第一次看到,当时我也以为是纯粹的返回单个数据对象 ...

  7. 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+SpringMVC项目详解

    http://blog.csdn.net/noaman_wgs/article/details/53893948 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+Spri ...

  8. MyBatis的动态SQL详解

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...

  9. Solr安装入门、查询详解

    Solr安装入门:http://www.importnew.com/12607.html 查询详解:http://www.360doc.com/content/14/0306/18/203871_35 ...

  10. Qt零基础教程(四) QWidget详解篇

    在博客园里面转载我自己写的关于Qt的基础教程,没次写一篇我会在这里更新一下目录: Qt零基础教程(四) QWidget详解(1):创建一个窗口 Qt零基础教程(四) QWidget详解(2):QWid ...

随机推荐

  1. ES6 学习笔记(一)let、const与作用域

    一.let命令 1.1用法 1.1.1 let类似于var,但所声明的变量只在let命令所在的代码块有效. 如: { let a = 10 var b = 20 } console.log(b) co ...

  2. 部署redis集群

    1.redis部署 redis单实例部署参考:https://www.cnblogs.com/silgen/p/16537299.html 版本:6.2.7 集群:6个节点(redis集群至少3个节点 ...

  3. Oracle数据库的导出和导入

    本次数据库的导入导出操作是导出公司环境的Oracle数据库,再导入本地数据库,采用impdp和expdp命令进行导入导出操作. 一.导出52数据库 1.用system用户登录到数据库,查看是否有创建d ...

  4. 深度学习之深L层神经网络

    声明 本文参考(8条消息) [中文][吴恩达课后编程作业]Course 1 - 神经网络和深度学习 - 第四周作业(1&2)_何宽的博客-CSDN博客 力求自己理解,刚刚走进深度学习希望可以一 ...

  5. 记一次spark数据倾斜实践

    参考文章: 大数据项目--倾斜数据的分区优化 数据倾斜概念 什么是数据倾斜   大数据下大部分框架的处理原理都是参考mapreduce的思想:分而治之和移动计算,即提前将计算程序生成好然后发送到不同的 ...

  6. 正则表达式之前戏、字符组、量词、特殊符号、贪婪与非贪婪匹配等,python正则模块之re

    目录 正则表达式前戏 正则表达式之字符组 正则表达式之特殊符号 正则表达式之量词 贪婪匹配与非贪婪匹配 转义符 正则表达式实战建议 re模块 re模块补充说明 作业 正则表达式前戏 案例:京东注册手机 ...

  7. 前后端结合解决Excel海量公式计算的性能问题

    背景 在数据密集的业务领域,尤其是金融,保险,税务等行业中,经常需要利用Excel模型,来对业务进行分析和处理.例如: 1.金融投资: 根据模型进行估值计算,并对投资风险进行评估,通过测算出投资的内部 ...

  8. 关于CSDN微信登录接口的研究

    代码 import requests import re from threading import Thread import time import requests from io import ...

  9. SSH(一)架包的引入

    一年多未使用了,有些东西真的会忘. 一.ssh的图形化记忆运作流程 二.Struts2.hibernate.spring需要引用的jar包 Struts2: 基本开发:struts-2.3.32\ap ...

  10. 2023年 DevOps 七大趋势

    随着时间的推移,很明显 DevOps 已经成为最高效的敏捷框架中的无人不知晓的名字.越来越多的企业(包括各类规模企业)正在采用 DevOps 方法来简化其运营效率.DevOps 的新时代趋势已经见证了 ...