05 动力云客之分页查询用户 + 查询用户详情 + 新增用户

1. 用户列表分页查询实现

核心

  1. 使用pageHelper实现分页
    @GetMapping(value = "api/users")//分页的参数可以不传, 不传就默认设置为1public R userPage(@RequestParam(value = "current", required = false) Integer current) {if (current == null) {current = 1;}PageInfo<TUser> pageInfo = userService.getUserByPage(current);return R.OK(pageInfo);}
    PageInfo<TUser> getUserByPage(Integer current);//用户列表分页查询实现@Overridepublic PageInfo<TUser> getUserByPage(Integer current) {//每个方法前用startPage设置一下分页参数PageHelper.startPage(current, Constants.PAGE_SIZE);List<TUser> list =  tUserMapper.selectUserByPage();//用户对象封装到list , list进一步封装到PageInfo里并返回//pageInfo可以获得一些分页参数,如总页数、总记录数、当前页数PageInfo<TUser> tUserPageInfo = new PageInfo<>(list);return tUserPageInfo;}
	  <select id="selectUserByPage" resultMap="BaseResultMap">select<include refid="Base_Column_List" />from dlyk.t_user</select>

2. 查询用户详情

核心:

  1. 将这个用户在表中的所有字段展示出来(密码除外)

  2. 相应地带来第二个问题, 如果只是简单查询一次用户表, 只能得到创建人, 编辑人的id, 这当然不合理 , 我们想要直接看到创建人的姓名. 这就需要多表一对一查询.
    在这里插入图片描述

2.1 先获得所有信息

    //查询用户详情, 路径传参@GetMapping(value = "api/user/{id}")public R userDetail(@PathVariable(value = "id") Integer id) {TUser tUser = userService.getUserById(id);return R.OK(tUser);}
    TUser getUserById(Integer id);@Overridepublic TUser getUserById(Integer id) {return tUserMapper.selectByPrimaryKey(id);}

这个方法已经自动生成好了, mapper接口和mapperxml都已经有了

    TUser selectByPrimaryKey(Integer id);

2.2 解决一对一映射

既然MB生成的mapper接口方法和mapperxml无法实现需求, 就手动写

  1. 修改UserServiceImpl中的mapper接口方法调用
		@Overridepublic TUser getUserById(Integer id) {//selectDetailById是自定义的方法return tUserMapper.selectDetailById(id);}
  1. mapper接口和mapperxml
    <select id="selectDetailById" parameterType="java.lang.Integer" resultMap="BaseResultMap"><!--@mbg.generated-->selecttu.*,tu2.id createById, tu2.name createByName,tu3.id editById, tu3.name editByName
<!--    一(user)对一(user), 只知道创建人的id, 要查创建人的姓名, 当然还是要从user表中查一-->from dlyk.t_user tu left join dlyk.t_user tu2 on tu.create_by = tu2.idleft join dlyk.t_user tu3 on tu.edit_by = tu3.idwhere id = #{id,jdbcType=INTEGER}</select>

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SORA 到底是什么?如何用bitget wallet购买?

什么是SORA&#xff1f; SORA 是一种模因币&#xff0c;灵感来自 OpenAI 最新的人工智能模型 Sora&#xff0c;它巧妙地根据文本输入生成视频。 SORA 诞生于加密社区内人工智能项目的热潮中&#xff0c;利用 OpenAI 的公告推出了一种独特且时尚的数字资产。正如 memecoin 网站…

浅析ARMv8体系结构:原子操作

文章目录 概述LL/SC机制独占内存访问指令多字节独占内存访问指令 独占监视器经典自旋锁实现 LSE机制原子内存操作指令CAS指令交换指令 相关参考 概述 在编程中&#xff0c;当多个处理器或线程访问共享数据&#xff0c;并且至少有一个正在写入时&#xff0c;操作必须是原子的&a…

react-组件基础

1.目标 能够使用函数创建组件 能够使用class创建组件 能够给React元素绑定事件 能够使用state和setState() 能够处理事件中的this指向问题 能够使用受控组件方式处理表单 2.目录 React组件介绍 React组件的两种创建方式 React事件处理 有状态组件和无状态组件 组件中的state…

Leetcoder Day26| 回溯part06:总结+三道hard题

332.重新安排行程 给定一个机票的字符串二维数组 [from, to]&#xff0c;子数组中的两个成员分别表示飞机出发和降落的机场地点&#xff0c;对该行程进行重新规划排序。所有这些机票都属于一个从 JFK&#xff08;肯尼迪国际机场&#xff09;出发的先生&#xff0c;所以该行程必…

4.1.CVAT——目标检测的标注详细步骤

文章目录 1. 进入任务1. 创建任务2. 已创建的task3. 进入标注界面 2. 选择标注类型2.1 选择标注类型2.2 进行标注2.3 遮挡 2.快捷键3.导出标注结果 1. 进入任务 登录后会看到如下图界面&#xff0c;CVAT的标注最小单位是Task&#xff0c;每个Task为一个标注任务。点击Task按钮…

gitlab添加ssh公钥

一&#xff1a;生成公钥 桌面鼠标右击打开 Open Git Bash here (前提是安装了Git)&#xff1b; 2.输入命令 ssh-keygen -t rsa -C "123*****90qq.com"来生成新的密钥对,将其中的"123*****90qq.com"替换为你自己的电子邮件地址。 命令&#xff1a;ssh-keyg…

安全运营中心(SOC)综合指南

什么是安全运营中心&#xff08;SOC&#xff09; 安全运营中心&#xff0c;也称为信息安全运营中心 &#xff08;ISOC&#xff09;&#xff0c;是结构良好的网络安全战略的核心。安全运营中心是一个集中式枢纽&#xff0c;无论是在组织内部还是外包&#xff0c;都致力于对整个…

最优二叉搜索树 C#实现

最优二叉搜索树 C#实现 介绍一下 上一篇博文搞半天挺烧脑&#xff0c;没搞清楚继续… 主要是练习动态规划算法。最关键的一个是这个最优二叉搜索树能干啥。我认为如果数据稳定&#xff0c;统计出概率来&#xff0c;用最优二叉树保存&#xff0c;以后搜索应该是效率比较高的。…

前端基础面试题(二)

摘要&#xff1a;最近&#xff0c;看了下慕课2周刷完n道面试题&#xff0c;记录下... 1. offsetHeight scrollHeight clientHeight 区别 计算规则&#xff1a; offsetHeight offsetWidth : border padding content clientHeight clientWidth: padding content scrollHeight…

zk和etcd的读一致性对比

背景 zk和etcd都是日常我们用到的分布式一致性的组件集群&#xff0c;不过他们在读一致性上还是有一些差别的&#xff0c;本文就来对比一下 zk和etcd的读一致性对比 如果读客户端没有通过zk或者etcd自带的watcher监听的方式监听某个写客户端写入的内容&#xff0c;而是依赖写…

前端架构: 脚手架命令行交互核心实现之inquirer和readline的应用教程

命令行交互核心实现 核心目标&#xff1a;实现命令行行交互&#xff0c;如List命令行的交互呢比命令行的渲难度要更大&#xff0c;因为它涉及的技术点会会更多它涉及以下技术点 键盘输入的一个监听 (这里通过 readline来实现)计算命令行窗口的尺寸清屏光标的移动输出流的静默 …

详解Kotlin中run、with、let、also与apply的使用和区别

Kotlin作为一种现代、静态类型的编程语言&#xff0c;不仅提供了丰富的特性&#xff0c;还提供了极具表现力的函数&#xff1a;run, with, let, also, 和 apply。理解这些函数的不同之处对于编写高效、易于维护的代码至关重要。 函数对比表 函数对象引用返回值使用场景runthi…