MyBatis学习笔记(六) —— MyBatis的各种查询功能

news2024/9/29 13:20:22

6、MyBatis的各种查询功能

6.1、查询一个实体类对象

SelectMapper.java接口

/**
 * 根据用户id查询用户信息
 * @param id
 * @return
 */
User getUserById(@Param("id") int id);

SelectMapper.xml

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

SelectMapperTest.java

@Test
public void testGetUserById(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
    User user = mapper.getUserById(1);
    System.out.println(user);
}

运行测试

DEBUG 02-25 02:33:02,731==> Preparing: select * from t_user where id = ? (BaseJdbcLogger.java:137)

DEBUG 02-25 02:33:02,757==> Parameters: 1(Integer) (BaseJdbcLogger.java:137)

DEBUG 02-25 02:33:02,777<== Total: 1 (BaseJdbcLogger.java:137)

User{id=1, username=‘admin’, password=‘123456’, age=23, gender=‘男’, email=‘12345@qq.com’}

6.2、查询一个list集合

若sql语句查询的结果为多条时,一定不能以实体类类型作为方法的返回值,

否则会抛出异常 TooManyResultsException

若sql语句查询的结果为1条时,此时可以使用实体类类型或list集合类型作为方法的返回值

SelectMapper.java接口

/**
* 查询所有的用户信息
* @return
*/
List<User> getAllUser();

SelectMapper.xml

<select id="getAllUser" resultType="User">
  select * from t_user
</select>

当查询的数据为多条时,不能使用实体类作为返回值,否则会抛出异常TooManyResultsException;

但是若sql语句查询的结果为1条时,此时可以使用实体类类型或list集合类型作为方法的返回值。

运行测试:

DEBUG 02-25 02:33:28,173==> Preparing: select * from t_user (BaseJdbcLogger.java:137)

DEBUG 02-25 02:33:28,198==> Parameters: (BaseJdbcLogger.java:137)

DEBUG 02-25 02:33:28,215<== Total: 4 (BaseJdbcLogger.java:137)

User{id=1, username=‘admin’, password=‘123456’, age=23, gender=‘男’, email=‘12345@qq.com’}

User{id=2, username=‘root’, password=‘123456’, age=33, gender=‘女’, email=‘123@qq.com’}

User{id=3, username=‘zhangsan’, password=‘123’, age=23, gender=‘男’, email=‘123@qq.com’}

User{id=4, username=‘lisi’, password=‘123’, age=null, gender=‘null’, email=‘null’}

6.3、查询单个数据

SelectMapper.java接口

查询用户总数

/**
* 查询用户的总数量
* @return
*/
Integer getCount();

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">
<mapper namespace="com.fan.mybatis.mapper.SelectMapper">
  <!--
  MyBatis中为Java中常用的类型设置了类型别名
  Integer: Integer,int
  int: _int,_integer
  Map: map
  String: string
  -->
  <select id="getCount" resultType="int">
    select count(*) from t_user
  </select>
</mapper>

SelectMapperTest.java

@Test
public void testGetCount(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
    Integer count = mapper.getCount();
    System.out.println(count);
}

运行测试:

DEBUG 02-25 02:41:42,727==> Preparing: select count(*) from t_user (BaseJdbcLogger.java:137)

DEBUG 02-25 02:41:42,749==> Parameters: (BaseJdbcLogger.java:137)

DEBUG 02-25 02:41:42,766<== Total: 1 (BaseJdbcLogger.java:137)

4

img

img

count()中的根据某个字段查询数据数量,若查询出来的结果中的某个字段为null,字段为null的数据不会放入map集合中。

img

img

6.4、查询一条数据为map集合

SelectMapper.java接口

/**
* 根据id查询用户信息为map集合
* @param id
* @return
*/
Map<String,Object> getUserByIdToMap(@Param("id") Integer id);

SelectMapper.xml

<select id="getUserByIdToMap" resultType="map">
  select * from t_user where id = #{id}
</select>

SelectMapperTest.java

@Test
public void testGetUserByIdToMap(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
    Map<String, Object> map = mapper.getUserByIdToMap(1);
    //查询一条数据转换为map集合
    //{password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin}
    System.out.println(map);//map集合没有固定的键,如果查询出来的结果集里某个字段为Null,这个字段是不会放在map集合中的。
}

运行测试:

img

img

6.5、查询多条数据为map集合

若查询的数据有多条时,并且要将每条数据转换为map集合。

有两种解决方案:

1、将mapper接口方法的返回值设置为泛型是map的list集合。

List<Map<String,Object>> getAllUserToMap();

结果:

[
 {password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin},
 {password=123456, gender=女, id=2, age=33, email=123@qq.com, username=root}, 
 {password=123, gender=男, id=3, age=23, email=123@qq.com, username=zhangsan}, 
 {password=123, id=4, username=lisi}
]

2、可以将每条数据转换的map集合放在一个大的map中,但是必须要通过 @MapKey 注解,将查询的某个字段的值作为map的键。

@MapKey(“id”)

Map<String,Object> getAllUserToMap();

结果:

{
 1={password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin},
 2={password=123456, gender=女, id=2, age=33, email=123@qq.com, username=root},
 3={password=123, gender=男, id=3, age=23, email=123@qq.com, username=zhangsan},
 4={password=123, id=4, username=lisi}
}

方式一:使用能存储map集合的List集合,作为方法的返回值。

SelectMapper.java 接口

/**
* 查询所有的用户信息为map集合
* @return
*/
List<Map<String,Object>> getAllUserToMap();

SelectMapper.xml

<select id="getAllUserToMap" resultType="map">
  select * from t_user
</select>

SelectMapperTest.java

@Test
public void testGetAllUserToMap(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
    List<Map<String, Object>> list = mapper.getAllUserToMap();
    System.out.println(list);
}

运行测试

DEBUG 02-25 14:34:25,385==> Preparing: select * from t_user (BaseJdbcLogger.java:137)

DEBUG 02-25 14:34:25,402==> Parameters: (BaseJdbcLogger.java:137)

DEBUG 02-25 14:34:25,421<== Total: 4 (BaseJdbcLogger.java:137)

[{password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin}, {password=123456, gender=女, id=2, age=33, email=123@qq.com, username=root}, {password=123, gender=男, id=3, age=23, email=123@qq.com, username=zhangsan}, {password=123, id=4, username=lisi}]

方式二:使用@MapKey()注解设置Map集合的键

Map集合中也可以存储多条数据,可以直接把每一条数据转换为Map集合放入List集合中,不能把每条转换为Map集合的数据放入Map集合中。map集合是键值对。查询出来的数据可以作为值。

注解:@MapKey() 把当前查询的数据所转换的Map集合,放入到一个大的Map集合中,通过@MapKey注解设置Map集合的键。

比如:@MapKey(“id”) 括号中id是以查询出来数据的字段id作为键,它的值就是每一条数据转换的Map集合。

SelectMapper.java接口

/**
* 方式二:查询所有的用户信息为map集合
* @return
*/
@MapKey("id")
Map<String,Object> getAllUserToMap2();

SelectMapper.xml

<select id="getAllUserToMap2" resultType="map">
  select * from t_user
</select>

SelectMapperTest.java

@Test
public void testGetAllUserToMap2(){
    SqlSession sqlSession = SqlSessionUtils.getSqlSession();
    SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
    /**
	 * {
	 * 1={password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin},
	 * 2={password=123456, gender=女, id=2, age=33, email=123@qq.com, username=root},
	 * 3={password=123, gender=男, id=3, age=23, email=123@qq.com, username=zhangsan},
	 * 4={password=123, id=4, username=lisi}
	 * }
	 */
    Map<String,Object> map = mapper.getAllUserToMap2();
    System.out.println(map);
}

运行测试:

DEBUG 02-25 15:33:21,599==> Preparing: select * from t_user (BaseJdbcLogger.java:137)

DEBUG 02-25 15:33:21,622==> Parameters: (BaseJdbcLogger.java:137)

DEBUG 02-25 15:33:21,638<== Total: 4 (BaseJdbcLogger.java:137)

{1={password=123456, gender=男, id=1, age=23, email=12345@qq.com, username=admin}, 2={password=123456, gender=女, id=2, age=33, email=123@qq.com, username=root}, 3={password=123, gender=男, id=3, age=23, email=123@qq.com, username=zhangsan}, 4={password=123, id=4, username=lisi}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/370875.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第十三届蓝桥杯国赛 C++ B 组 J 题——搬砖(AC)

目录1.搬砖1.题目描述2.输入格式3.输出格式4.样例输入5.样例输出6.数据范围7.原题链接2.解题思路3.Ac_code1.搬砖 1.题目描述 这天&#xff0c;小明在搬砖。 他一共有 nnn 块砖, 他发现第 iii 砖的重量为 wiw_{i}wi​, 价值为 viv_{i}vi​ 。他突然想从这些 砖中选一些出来从…

JVM的内存结构

一.引言 1.什么是 JVM &#xff1f; 1&#xff09;定义&#xff1a; Java Virtual Machine - java 程序的运行环境&#xff08;java 二进制字节码的运行环境&#xff09; 2&#xff09;好处&#xff1a; 一次编写&#xff0c;到处运行自动内存管理&#xff0c;垃圾回收功能…

在服务器上指定GPU跑代码

一、准备工作 查看GPU状态和信息&#xff0c;找到空闲的GPU&#xff1a; nvidia-smi 二、指定单GPU 从图中 Processes 表格我们可以发现0、1、2号GPU均是可以利用的。于是我们可以在python文件中加入以下代码&#xff0c;表示使用0号GPU&#xff1a; import os os.environ…

【数通网络交换基础梳理2】三层设备、网关、ARP表、VLAN、路由表及跨网段路由下一跳转发原理

一、不同网段如何通讯 同网段可以依靠二层交换机通讯&#xff0c;网络中存在多个网段192.168.1.1/24 172.16.1.1/24 173.73.1.1/24情况下如何互相通讯&#xff1f;上节留一下的问题&#xff0c;这节继续讲解。 1、这里以Ping命令讲解&#xff0c;PC1 ping173.73.1.2&#xf…

2023中职组网络安全技能竞赛——代码审计解析(超级详细)

代码审计:需求环境可私信博主 任务环境说明: 服务器场景:PYsystem0035服务器场景操作系统:未知服务器场景用户名:未知 密码:未知在渗透机Kali Linux中访问靶机服务器Web页面,注册账号并登陆,找到存在XSS执行漏洞的页面,将该页面中存在XSS执行漏洞的对象名作为FLAG提…

关于永中Office(永中办公软件)不认Windows系统安装的字体的解决办法

一位网友的电脑最近安装了永中Office软件&#xff0c;在使用过程中发现无法使用方正小标宋简体、仿宋GB2312等字体&#xff0c;这些字体在之前所用的微软Office中可以正常使用。他根据网上查到的一些的资料&#xff0c;将这些字体文件复制到C:\Program Files\Yozosoft\Yozo_Off…

【Java】CAS锁

一、什么是CAS机制&#xff08;compare and swap&#xff09; 1.概述 CAS的全称为Compare-And-Swap&#xff0c;直译就是对比交换。是一条CPU的原子指令&#xff0c;其作用是让CPU先进行比较两个值是否相等&#xff0c;然后原子地更新某个位置的值。经过调查发现&#xff0c;…

测试——基本概念

概念 测试和调试有以下几点区别&#xff1a; 测试是测试人员进行的工作&#xff0c;调试是开发人员调试是发现并解决问题&#xff0c;测试只是发现问题测试贯穿于整个项目的生命周期&#xff0c;而调试主要在编码阶段 测试人员一般有如下的工作&#xff1a; 需求分析&#x…

Spring MVC 源码- ViewResolver 组件

ViewResolver 组件ViewResolver 组件&#xff0c;视图解析器&#xff0c;根据视图名和国际化&#xff0c;获得最终的视图 View 对象回顾先来回顾一下在 DispatcherServlet 中处理请求的过程中哪里使用到 ViewResolver 组件&#xff0c;可以回到《一个请求响应的旅行过程》中的 …

进程地址空间(虚拟地址空间)

目录 引入问题 测试代码 引入地址空间 故事1&#xff1a; 故事二&#xff1a; 解决问题 为什么有虚拟地址空间 扩展 扩展1&#xff08;没有地址空间&#xff0c;OS如何工作&#xff09; 扩展2 &#xff08;代码只读深入了解&#xff09; 扩展3&#xff08;malloc本质…

0 初识Kotlin

0 基本介绍 相信很多开发者对Kotlin还是比较陌生的。 Kotlin是一种新型的编程语言&#xff0c;由JetBrains公司开发与设计&#xff0c;在2012年开源&#xff0c; 但没引起什么注意。 直到2017年google宣布将Kotlin作为Android开发的首选语言&#xff0c;Kotlin才开始大放异彩。…

基于MATLAB的MIMO预编码设计:优化迫零算法(附完整代码与分析)

目录 一.介绍 二. 对比本方案优化后的迫零算法与原始的迫零算法 三. 源代码 四. 运行结果及分析 4.1 天线数为8 4.2 天线数为128 一.介绍 图中“RF Chain” 全称为Radio Frequency Chain&#xff0c;代表射频链路。 此MIMO预编码包含了基带预编码W&#xff08;改变幅度和…

NVIDIA GPU开源驱动编译学习架构分析

2022年5月&#xff0c;社区终于等到了这一天&#xff0c;NVIDIA开源了他们的LINUX GPU 内核驱动&#xff0c; Linux 内核总设计师 Linus Torvalds 十年前说过的一句话&#xff0c;大概意思是英伟达是LINUX开发者遇到的硬件厂商中最麻烦的一个&#xff0c;说完这句话之后&#x…

20230225英语学习

Is Your Phone Heavier When It’s Full of Data? We’ve Done the Math 从数学角度看&#xff0c;充满数据的手机会更重吗&#xff1f; Here’s a weird question: does your phone weigh more when it’s “full” than when it’s “empty”?It sounds almost ridiculou…

【unity游戏制作-mango的冒险】场景二的镜头和法球特效跟随

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 秩沅 原创 收录于专栏&#xff1a;unity游戏制作 ⭐mango的冒险场景二——镜头和法球特效跟随⭐ 文章目录⭐mango的冒险场景二——镜…

C#的多线程、线程池和Task

线程 被定义为程序的执行路径。每个线程都定义了一个独特的控制流。如果您的应用程序涉及到复杂的和耗时的操作&#xff0c;那么设置不同的线程执行路径往往是有益的&#xff0c;每个线程执行特定的工作。 线程是轻量级进程。一个使用线程的常见实例是现代操作系统中并行编程的…

如何使用Python和ftplib模块连接到FTP服务器并列出远程目录中的文件?

ftp服务可以用在以下一些使用场景&#xff1a; 文件共享&#xff1a;使用Python和FTP服务器可以轻松地搭建一个文件共享服务&#xff0c;使得用户可以上传和下载文件&#xff0c;从而促进协作和信息共享。 数据备份&#xff1a;FTP可以用于将数据备份到另一个服务器或云存储中…

Git ---- GitHub 操作

Git ---- GitHub 操作1. 创建远程仓库2. 远程仓库操作1. 创建爱你远程仓库别名2. 推送本地分支到远程仓库3. 克隆远程仓库到本地4. 邀请加入团队5. 拉取远程库内容3. 跨团队协作4. SSH 免密登录GitHub 网址&#xff1a;https://github.com/ Ps&#xff1a;全球最大同性交友网站…

实现弹窗功能并修改其中一个系数

把鼠标放在number-info上面,会是一个delon/chart的类库,可以在NG-ALAIN上找到阅读NG ALAIN的图表,以及number-info样式,数据文本 它拥有[title] [subtitle]两个可以是TemplateRef类型的,而template可以在里面放一些东西,比如按钮,所以可以放一个修改按钮 这里刚开始把template放…

学习 Python 之 Pygame 开发魂斗罗(三)

学习 Python 之 Pygame 开发魂斗罗&#xff08;三&#xff09;继续编写魂斗罗1. 角色站立2. 角色移动3. 角色跳跃4. 角色下落继续编写魂斗罗 在上次的博客学习 Python 之 Pygame 开发魂斗罗&#xff08;二&#xff09;中&#xff0c;我们完成了角色的创建和更新&#xff0c;现…