尚庭公寓----------分页查询

根据条件分页查询公寓列表

进行分页配置

package com.nie.lease.common.mybatisplus;import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
@MapperScan("com.nie.lease.web.*.mapper")
@MapperScan("com.nie.lease.web.*.mapper")
public class MybatisPlusConfiguration {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}}

controller

package com.nie.lease.web.admin.controller.apartment;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.nie.lease.common.result.Result;
import com.nie.lease.model.entity.ApartmentInfo;
import com.nie.lease.model.enums.ReleaseStatus;
import com.nie.lease.web.admin.service.ApartmentInfoService;
import com.nie.lease.web.admin.vo.apartment.ApartmentDetailVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentItemVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentQueryVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentSubmitVo;
import com.baomidou.mybatisplus.core.metadata.IPage;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.checkerframework.checker.units.qual.A;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.util.List;@Tag(name = "公寓信息管理")
@RestController
@RequestMapping("/admin/apartment")
public class ApartmentController {@Operation(summary = "根据条件分页查询公寓列表")@GetMapping("pageItem")public Result<IPage<ApartmentItemVo>> pageItem(@RequestParam long current, @RequestParam long size, ApartmentQueryVo queryVo) {Page<ApartmentItemVo> page = new Page<>(current, size);IPage<ApartmentItemVo> result=apartmentInfoService.pageItem(page, queryVo);return Result.ok(result);}

service

package com.nie.lease.web.admin.service;import com.nie.lease.model.entity.ApartmentInfo;
import com.nie.lease.web.admin.vo.apartment.ApartmentDetailVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentItemVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentQueryVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentSubmitVo;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.IService;/**
* @author liubo
* @description 针对表【apartment_info(公寓信息表)】的数据库操作Service
* @createDate 2023-07-24 15:48:00
*/
public interface ApartmentInfoService extends IService<ApartmentInfo> {void saveOrUpdateApartment(ApartmentSubmitVo apartmentSubmitVo);IPage<ApartmentItemVo> pageItem(Page<ApartmentItemVo> page, ApartmentQueryVo queryVo);
}

service实现类

package com.nie.lease.web.admin.service.impl;import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.nie.lease.model.entity.*;
import com.nie.lease.model.enums.ItemType;
import com.nie.lease.web.admin.mapper.ApartmentInfoMapper;
import com.nie.lease.web.admin.service.*;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.nie.lease.web.admin.vo.apartment.ApartmentItemVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentQueryVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentSubmitVo;
import com.nie.lease.web.admin.vo.graph.GraphVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;import java.util.ArrayList;
import java.util.List;/*** @author liubo* @description 针对表【apartment_info(公寓信息表)】的数据库操作Service实现* @createDate 2023-07-24 15:48:00*/
@Service
public class ApartmentInfoServiceImpl extends ServiceImpl<ApartmentInfoMapper, ApartmentInfo>implements ApartmentInfoService {@Autowiredprivate ApartmentInfoMapper apartmentInfoMapper;@Overridepublic IPage<ApartmentItemVo> pageItem(Page<ApartmentItemVo> page, ApartmentQueryVo queryVo) {return apartmentInfoMapper.pageItem(page, queryVo);}
}

mapper接口

package com.nie.lease.web.admin.mapper;import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.nie.lease.model.entity.ApartmentInfo;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.nie.lease.web.admin.vo.apartment.ApartmentItemVo;
import com.nie.lease.web.admin.vo.apartment.ApartmentQueryVo;/**
* @author liubo
* @description 针对表【apartment_info(公寓信息表)】的数据库操作Mapper
* @createDate 2023-07-24 15:48:00
*/
public interface ApartmentInfoMapper extends BaseMapper<ApartmentInfo> {IPage<ApartmentItemVo> pageItem(Page<ApartmentItemVo> page, ApartmentQueryVo queryVo);
}

mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.nie.lease.web.admin.mapper.ApartmentInfoMapper"><select id="pageItem" resultType="com.nie.lease.web.admin.vo.apartment.ApartmentItemVo">select ai.id,ai.name,ai.introduction,ai.district_id,ai.district_name,ai.city_id,ai.city_name,ai.province_id,ai.province_name,ai.address_detail,ai.latitude,ai.longitude,ai.phone,ai.is_release,ifnull(tc.cnt,0) total_room_count,tc.cnt - ifnull(cc.cnt,0) free_room_countfrom (select id,name,introduction,district_id,district_name,city_id,city_name,province_id,province_name,address_detail,latitude,longitude,phone,is_releasefrom apartment_info<where>is_deleted=0<if test="queryVo.provinceId !=null">and province_id=#{queryVo.provinceId}</if><if test="queryVo.cityId !=null">and city_id=#{queryVo.cityId}</if><if test="queryVo.districtId !=null">and district_id=#{queryVo.districtId}</if></where>) aileft join(select apartment_id,COUNT(*) cntfrom room_infowhere is_deleted = 0and is_release = 1group by apartment_id) tcon ai.id = tc.apartment_idleft join(select apartment_id,COUNT(*) cntfrom lease_agreementwhere is_deleted = 0and status in (2, 5)group by apartment_id) ccon ai.id = cc.apartment_id</select>
</mapper>

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

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

相关文章

【图像质量评价指标】图像熵(Image Entropy) —— 熵值饱和现象

文章目录一、图像熵&#xff08;Image Entropy&#xff09;&#xff08;1&#xff09;基本原理&#xff08;2&#xff09;优势与局限&#xff08;3&#xff09;推荐策略多指标联合推荐体系噪声应对机制建议二、项目实战 —— 通过图像熵评价序列图像&#xff0c;并提取最优图像…

GaussDB in的用法

1 in的作用in运算符允许您在WHERE子句中指定多个值。 in运算符是多个OR条件的简写。2 in的语法select column_name(s) from table_name where column_name in (value1, value2, ...); 或者 select column_name(s) from table_name where column_name in (select statement);3 i…

【C语言进阶】内存函数

目录 1.memcpy函数 1.1 模拟实现 2.memmove函数 3.memcmp函数 1.memcpy函数 字符串拷贝strcpy和strncpy是有一定局限性的&#xff0c;只能拷贝字符串&#xff0c;而memcpy可以拷贝任意类型的数据&#xff0c;单位是字节。 1.1 模拟实现 #include<stdio.h> #include&l…

从乱序到整洁:Swift 实现奇偶链表重排的最佳方案

文章目录摘要描述题解答案题解代码分析分段讲解示例测试及结果时间复杂度空间复杂度总结摘要 在开发中&#xff0c;链表结构经常出现在缓存淘汰、操作系统任务调度、或是 LRU 算法中&#xff0c;尤其是对节点位置的灵活操作更是链表的强项。LeetCode 第 328 题「奇偶链表」就给…

WPF+CEF 执行JS报错

WPFCEF 执行JS报错 在WPF中执行 webBrowser.EvaluateScriptAsync(“window.scrollBy(0, 1000);”); 在部分网站会报异常&#xff1a; Request BrowserId : XXXX not found it’s likely the browser is already closed环境 .Net Framework 4.7 CefSharp.Wpf 131.3.50 解决方案&…

【Python3-Django】快速掌握DRF:ModelViewSet实战指南

DRF讲解 1. 什么是 Django 和 Django REST Framework&#xff1f; 在深入 ModelViewSet 之前&#xff0c;我们先简单了解一下背景知识&#xff1a; Django 是一个基于 Python 的 Web 开发框架&#xff0c;旨在帮助开发者快速构建安全、可扩展的 Web 应用。它遵循“不要重复自己…

TRAE IDE** 下载、安装、开发、测试和部署 2048 小游戏的全流程指南

以下是一份完整的 TRAE IDE 下载、安装、开发、测试和部署 2048 小游戏的全流程指南。整个过程基于 TRAE 作为 AI 辅助编程工具的特性&#xff08;对标 Cursor/AWS Kiro&#xff09;&#xff0c;假设它支持智能代码生成和云部署功能。 【插播】腾讯云AI Coding大赛https://mar…

重学前端005 --- 响应式网页设计 CSS 盒子模型

文章目录BOX 盒子概念CSSoverflow: hidden;filter: blur(3px);box-shadow: 0 0 3px 3px #efb762;border-radius: 30px 25px 60px 12px;transform: rotate(-0.6deg);每个 HTML 元素都是一个盒子&#xff0c;它拥有着自己的间距和边框。这叫作“盒子模型”。 BOX 盒子概念 内容…

TC500R立式加工中心主轴箱机械结构设计cad【11张】三维图+设计说明书

TC500R立式加工中心主轴箱机械结构设计 摘 要 数控机床作为工业制造的基础&#xff0c;在国家的发展中起着非常重要的作用。随着我国经济的快速发展&#xff0c;我国已经成为工业制造大国&#xff0c;制造业的发展离不开数控机床&#xff0c;而TC500R立式加工中心作为数控机床…

CSS Grid布局:构建现代网页的强大网格系统

目录 一、Grid布局基础概念 1.1 网格容器与网格项 1.2 创建基本网格 二、核心属性详解 2.1 定义网格轨道 2.2 网格间距控制 2.3 网格项对齐方式 三、实战布局技巧 3.1 创建经典布局 3.2 网格项定位技巧 3.3 响应式网格设计 四、Grid布局 vs Flexbox布局 五、高级…

Elasticsearch / MongoDB / Redis / MySQL 区别

1、一句话简介名称核心用途Elasticsearch强大的全文检索与日志分析引擎MongoDB灵活的文档数据库&#xff0c;适合半结构化/结构化数据Redis高性能的内存键值缓存数据库&#xff0c;用于实时高并发处理MySQL经典关系型数据库&#xff0c;强事务支持&#xff0c;结构化数据持久存…

网络通信之基础知识

一、什么是计算机网络&#xff1f;计算机网络是指由若干主机、通信链路和网络设备&#xff08;如路由器、交换机等&#xff09;组成的系统&#xff0c;借助通信协议&#xff0c;实现信息共享和资源互联。其本质是&#xff1a;多台设备之间通过协议进行数据交换。二、网络协议与…

Java 设计模式及应用场景

Java 设计模式是解决软件开发中常见问题的通用方案&#xff0c;通过合理的设计模式可以提高代码的可维护性、可扩展性和复用性。下面将介绍 Java 中常见的设计模式及其原理。一、设计模式的分类设计模式主要分为三大类&#xff0c;共 23 种经典模式&#xff1a;创建型模式&…

GitHub Jekyll博客本地Win开发环境搭建

GitHub Jekyll博客本地Win开发环境搭建 标签 后端 blog jekyll 全文链接 GitHub Jekyll博客本地Win开发环境搭建 概述 本文详细介绍了在Windows系统上搭建Jekyll博客本地开发环境的完整步骤&#xff0c;为GitHub Pages博客开发提供本地预览和调试能力。 环境依赖 Ruby环…

浏览器防录屏是怎样提高视频安全性?

文章目录前言一、什么是浏览器防录屏二、浏览器防录屏的原理是什么&#xff1f;&#xff08;javascript&#xff09;三、如何实现浏览器防录屏总结前言 在数字内容版权保护面临严峻挑战的今天&#xff0c;浏览器防录屏技术作为视频安全体系的关键一环&#xff0c;其重要性日益…

uni-app项目配置通用链接拉起ios应用android应用

uniapp开发ios&android可拉起app的辛酸历程IOS配置指南1、登录[apple Developer](https://developer.apple.com/account/resources/identifiers/list)账户找到自己开发的对应的项目2、确保对应项目的Associated Domains是打开状态3、本地创建一个 apple-app-site-associati…

deep learning(李宏毅)--(六)--loss

一&#xff0c;关于分类问题及其损失函数的一些讨论。 在构建分类模型是&#xff0c;我们的最后一层往往是softmax函数&#xff08;起到归一化的作用&#xff09;&#xff0c;如果是二分类问题也可以用sigmoid函数。 在loss函数的选择上&#xff0c;一般采用交叉熵损失函数(…

Python绑定及其在Mujoco仿真器中的作用

好的&#xff0c;这是一个非常核心且重要的问题。我来分两部分为你详细解释&#xff1a;首先是“什么是Python绑定”&#xff0c;然后是“它在MuJoCo中具体的作用”。第一部分&#xff1a;什么是Python绑定 (Python Binding)&#xff1f; 简单来说&#xff0c;Python绑定是一座…

数学建模从入门到国奖——备赛规划优秀论文学习方法

数学建模从入门到国奖——备赛规划 数学建模国一&#xff1a;我的逆袭经验分享在大二&#xff0c;我们团队初次参加妈妈杯&#xff0c;遗憾未获奖&#xff0c;后来经过5个月的时间&#xff0c;在大三上学期的9月&#xff0c;我们团队以C题数据挖掘机器学习创新斩获国赛一等奖&a…

大型语言模型的白日梦循环

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…