一个可以通过多个条件筛选的系统界面是如何实现的(springboot+mybatis)

比如我们有一个订单记录管理界面

条件可以通过订单号、商品名称、创建日期范围、价格范

围。。。来进行筛选查询。

首先我们先确定数据库订单表(我这里就不做连表了,都

放在一个表中)模拟一个订单表

order表

订单号

商品名称

创建日期

价格

地址

用户

121

飞机

2023-03-23

199

bj

xxx

212

大炮

2023-04-23

29

bj

xxx

就比如我们有一个这样的订单表,

前端的话说一下思路,就不做演示了,我们将查询的

每个字段当作参数传递给后端(我们可以通过order实

体类来接受,此时要注意前端字段命名问题了,但是

时间和价格都是一个范围,包括开始时间-结束时间,

我们实体类中没有这个字段,此时我们就需要添加一

个DTO来继承那个实体类,在DTO中添加这几个实体

类中没有的但是我们查询过程中会用到的字段,通过

DTO来接受参数,注意:前端通过JSON传入后端,

后端通过@RequestBody接收)

如果不懂怎么写的可以去看下我的这个文章前后端交互问题

如果没什么特殊的业务操作我们的业务层和控制层基本

不用写代码(记得时间要格式化);

实现条件查询做重要的的部分来了也就是我们的sql语句

这里我们使用mybatis的 .xml配置文件来写sql

这里sql中就用到动态拼接的方法,也就是<where> <if> ....

本文实现功能只用到了这两个,其他你们可以去了解

//这里的resultMap="BaseResultMap"可以改成resultType="DTO类的全路径"

<select id="selectOrder" resultMap="BaseResultMap">
selecttipo.id, tipo.prizes_name,tipo.Receive_address_id, tipo.create_time,tipo.Audit_time,tipo.integral, tipo.user_namefromt_order tipo<where>'1'='1'<if test="prizesName != null and prizesName != ''">and tip.prizes_name = #{prizesName}</if><if test="startIntegral != null and startIntegral != ''"><if test="endIntegral != null and endIntegral != ''">and tip.prizes_integral between #{startIntegral} and #{endIntegral}</if></if><if test="changeStartTime != null and changeStartTime != ''"><if test="changeEndTime != null and changeEndTime != ''">and tipo.create_time between #{changeStartTime} and #{changeEndTimestartTime}</if></if></where>order by tipo.create_time</select>

再比如:

<select id="selectOrder" resultMap="BaseResultMap">selectid, prizes_name,Receive_address_id, create_time,Audit_time,integral, user_namefromt_order <where>'1'='1'<if test="prizesName != null and prizesName != ''">and prizes_name = #{prizesName}</if><if test="startIntegral != null and startIntegral != ''"><if test="endIntegral != null and endIntegral != ''">and prizes_integral between #{startIntegral} and #{endIntegral}</if></if>
//foreach的使用<if test="ids!= null and ids.length!=0">id IN<foreach item="id" collection="ids" open="(" separator="," close=")">#{id}</foreach></if></where>order by create_time</select>

上面我们就通过动态拼接实现了按多条件查询的例子啦~,上面这

种也可以不通过sql,直接在前端使用filter进行实现(可以提高用

户体验,秒速查询)可以去看这个vue实现过滤器,但是这种情况

不能用于数据变化频率高的情况,因为在前端筛选不会重新查询数

据库,也不能实时更新

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

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

相关文章

telnet和ping的区别

文章目录 telnet和ping的作用和区别用telnet测试主机端口的原因 telnet和ping的作用和区别 Telnet和Ping是两种常用的网络工具&#xff0c;它们的作用和功能有以下区别&#xff1a; Telnet&#xff08;远程终端协议&#xff09;&#xff1a;Telnet是一种远程登录协议&#xf…

【ADS】在同一个symbol层次化实现理想器件和EM仿真的切换

ADS层次化切换理想器件和电磁仿真 1.需求描述2.实现步骤2.1 层次结构2.2 新建schematic2.3 新建symbol2.4 使用演示 3.后言 1.需求描述 在使用ADS做电磁仿真时&#xff0c;得到的结果需要多次迭代去接近原理图&#xff0c;那么就需要反复与原理图切换进行对比。 比较直接的方法…

canvas实现代码雨

学习抖音&#xff1a; 渡一前端必修课 效果图&#xff1a; 全部代码&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge">&…

flinksql sink to sr often fail because of nullpoint

flinksql or DS sink to starrocks often fail because of nullpoint flink sql 和 flink ds sink starrocks 经常报NullpointException重新编译代码 并上传到flink 集群 验证&#xff0c;有效 flink sql 和 flink ds sink starrocks 经常报NullpointException 使用flink-sta…

PHP流浪动物招领网站mysql数据库web结构apache计算机软件工程网页wamp

一、源码特点 PHP流浪动物招领网站 是一套完善的web设计系统&#xff0c;对理解php编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。 下载链接 nullhttps://download.csdn.net/download/qq_41221322/88190168视频演示 …

观察混合云环境中 Kubernetes 可观测性的 6 种有效策略

在混合云环境中观察Kubernetes需要理解分布式系统的行为和性能。我下面这篇文章中的六个策略可以帮助实现这一目标。 2023年&#xff0c;原生云应用和平台迅速增长。组织不断努力最大化其应用程序的潜力&#xff0c;确保无缝的用户体验&#xff0c;并推动业务增长。混合云环境…

O2OA开发平台实施入门指南

O2OA&#xff08;翱途&#xff09;开发平台&#xff0c;是一款适用于协同办公系统开发与实施的基础平台&#xff0c;说到底&#xff0c;它也是一款快速开发平台。开发者可以基于平台提供的能力完成门户、流程、信息相关的业务功能开发。 既然定位为开发平台&#xff0c;那么开…

RocketMQ 5.x如何使用GRPC方式发送消费消息

这里是weihubeats,觉得文章不错可以关注公众号小奏技术&#xff0c;文章首发。拒绝营销号&#xff0c;拒绝标题党 RocketMQ版本 5.1.0 背景 我们都知道RocketMQ 5.x新增了proxy模式部署方式&#xff0c;也就是支持了GRPC的消费方式消费&#xff0c;所以今天我们来试试 本次…

SAN共享存储架构

SAN共享存储架构 概述 近年在高性能专用存储网络需求的驱使下&#xff0c;许多SAN存储系统应用于高性能计算网络系统、大型网站系统、非线性编辑系统等网络系统中&#xff0c;存储设备与计算机主机系统之间一对一的关系&#xff0c;被可供多个计算机主机共享读写同一个存储设…

解决Consider the following: If you want an embedded database (H2, HSQL or Derby)

问题描述&#xff1a; 2023-08-10 11:52:32.992 ERROR 13064 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPLICATION FAILED TO START ***************************Description:Failed to configure a DataSource: url …

探究Vue源码:mustache模板引擎(10) 解决不能用连续点符号找到多层对象问题,为编译循环结构做铺垫

上文 探究Vue源码:mustache模板引擎(9) 将单层无喜欢结果tokens转为dom字符串 我们简单处理了 token转字符串的业务逻辑 但是 我们只处理了最贱的花括号 接下来 带着大家将井号的也处理一下 我们打开项目 将 www中的index.html代码改回之前的这样 <!DOCTYPE html> <h…

通过PMP考试的伙伴看过来!免试多拿一个证书!

有PMP电子证书或纸质证书的伙伴可以免考申领国家CSPM二级证书&#xff01;&#xff08;项目管理专业人员评价国标证书&#xff09;&#xff01;免试&#xff0c;多拿一个证书&#xff0c;真香&#xff01; 本周已经开始提交新一批名单! 现在持有PMP证书可以免培训、免考试申报…

改进的麻雀算法优化最大相关峭度解卷积(SCSSA-MCKD),实现早期微弱故障诊断,MATLAB代码实现

01 引言 由于一些设备的早期故障产生的冲击十分微弱&#xff0c;易被系统噪声干扰&#xff0c;如何有效地对设备的原始故障信号进行降噪并增强信号中微弱冲击成分&#xff0c;是进行该类部件早期故障诊断的关键。 最大相关峭度解卷积&#xff08;MCKD&#xff09;通过解卷积运算…

【UE】VS无法调试,不能进入断点、未命中断点、断点不可用解决办法

问题&#xff1a;通过 附加进程的方式 调试DS&#xff0c;部分代码可以打断点&#xff0c;部分无法打断点 原因&#xff1a;XP限制一次加载的dll符号不能超过500个 解决&#xff1a; WinR 打开regedit在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manag…

【HTML】label 标签

在HTML中&#xff0c;<label> 标签用于为表单元素创建标签文本或标题。它可以与输入字段&#xff08;如文本框、单选按钮、复选框等&#xff09;和其他表单元素关联起来&#xff0c;以提高可用性和可访问性。 <label> 元素有两种常见的用法&#xff1a; 包裹方式…

【VUE 监听用户滑动】

监听滑动方法 一. touchstart、touchmove、touchend二.v-touch三. 自定义指令 一. touchstart、touchmove、touchend 在 Vue 中监听用户往哪个方向滑动可以通过添加事件监听器&#xff0c;然后在事件回调函数中判断滑动方向。常用的事件监听器有touchstart、touchmove、touche…

leetcode 399-除法求值

法一&#xff1a;并查集 分析示例1&#xff1a; a / b 2.0 a/ b 2.0 a/b2.0&#xff0c;说明 a 2 b a2b a2b&#xff0c; a a a和 b b b在同一个集合中 b / c 3.0 b/c3.0 b/c3.0&#xff0c;说明 b 3 c b3c b3c&#xff0c; b b b和 c c c在同一个集合中 求 a / c a/…

24届近5年重庆邮电大学自动化考研院校分析

今天给大家带来的是重庆邮电大学控制考研分析 满满干货&#xff5e;还不快快点赞收藏 一、重庆邮电大学 学校简介 重庆邮电大学简称"重邮"&#xff0c;坐落于直辖市-重庆市&#xff0c;入选国家"中西部高校基础能力建设工程”、国家“卓越工程师教育培养计划…

c51单片机16个按键密码锁源代码(富proteus电路图)

注意了&#xff1a;这个代码你是没法直接运行的&#xff0c;但是如果你看得懂&#xff0c;随便改一改不超过1分钟就可以用 #include "reg51.h" #include "myheader.h" void displayNumber(unsigned char num) {if(num1){P10XFF;P10P11P14P15P160;}else if…

PyCharm新手入门指南

安装好Pycharm后&#xff0c;就可以开始编写第一个函数&#xff1a;Hello World啦~我们就先来学习一些基本的操作&#xff0c;主要包含新建Python文件&#xff0c;运行代码&#xff0c;查看结果等等。 文章主要包含五个部分&#xff1a; 一、界面介绍 主要分为菜单栏、项目目录…