尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

弹窗列表-时间筛选bug

弹窗列表-时间筛选bug
📅 发布时间:2026/6/19 3:15:33

弹窗列表-时间筛选bug

弹窗信息表,存储弹窗信息。有两个字段,存储开始时间和结束时间

1 create table notification(id int, start_tm datetime, end_tm datetime)

弹窗查询页面,有根据开始日期和结束日期筛选功能。传给后端的是日期date类型字符串如:"2025-12-01",fastapi框架自动转为date类型。展示数据库提示时间区间,查询区间有交集,展示出来。

查询筛选条件用的,取反。没有交集,然后取反,就是有交集。前端传的日期start_dt, end_dt。查询sql

select * from notification where not (start_tm >  end_dt or end_tm < start_dt) 

问题现象,提示时间开始时间、结束时间在同一天的。2025-12-01 00:000:00 ~ 2025-12-01 08:000:00 ,2025-12-02 08:000:00 ~ 2025-12-02 09:000:00。筛选条件start_dt和end_dt是同一天,只有1号可以查询到,2号查询不到。

原因分析:

date类型转datetime类型,时分秒,都会为00:00:00。导致,起止时间在同一天的,只有包含00:00:00的,才能筛选出来。

我当时想到的两个方案

解决方案:

1. 前端查时分秒给后端

2. sql做一下类型转换,datetime转成date类型

这两个方案,领导都觉得不好,同时要注意是否走了索引。

第一个方案:用户体验变差了,需要精确到时分秒

第二个方案:查询效率低,所有数据都要datetime转成date类型

领导给的方案,后端收到前端传的date后,后台代码转成datetime。转成00:00:00 ~ 23:59:59。

1. 前端不用修改,用户体验较好

2. 效率比较高

灰度发布后发现的,测试的时候要注意边界条件,提前发现问题。

Please call me JiangYouDang!

相关新闻

  • PassFab 4EasyPartition(系统迁移工具)
  • 4645645
  • 漸近正態性的必然歸宿——《高等应用概率》总结笔记

最新新闻

  • MCP3301与MCU的SPI通信:从原理到实践的高精度ADC应用指南
  • MCP3002 ADC芯片选型、驱动与低功耗系统设计实战指南
  • 2026最新领英账户解封全攻略指南:从领英封禁类型到高效申诉恢复实操
  • CMOS LDO选型与应用实战:TC1223/TC1224低功耗电源设计指南
  • 如何在Chrome浏览器中快速生成和识别二维码:终极二维码处理技巧指南
  • 风力发电机运行数据的分析与应用技巧

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号